当前位置: 首页 > news >正文

MyBatis 缓存与 Spring 事务相关笔记

一、MyBatis 缓存

  1. 缓存作用:减少对数据库的访问,提高查询效率。当进行两次相同的查询时,可直接使用缓存数据。
  2. 一级缓存
    • 默认开启
    • 级别:SQLSession 级别
    • 特点:必须是同一个 SQLSession 才会使用到缓存
  3. 二级缓存
    • 需要手动开启,使用<cache>标签启用
    • 级别:Mapper 级别
    • 特点:使用同一个 Mapper 查询同一个 SQL 且参数相同时,会击中缓存;二级缓存的数据需要可序列化

二、Spring 事务实现方式

  1. 编程式事务

    • 通过TransactionTemplate实现
    • 示例代码:
    @Autowired
    TransactionTemplate tt;@RequestMapping("testa")
    public void testTransaction(){tt.execute(new TransactionCallbackWithoutResult() {@Overrideprotected void doInTransactionWithoutResult(TransactionStatus status) {try{// 业务操作// ...} catch (Exception e) {status.setRollbackOnly(); // 发生异常时回滚}}});
    }
    
  2. 声明式事务

    • 通过@Transactional注解实现
    • 示例代码:
    @RequestMapping("testb")
    @Transactional(rollbackFor = Exception.class,isolation = Isolation.DEFAULT)
    public void testTransactionB(){// 业务操作// ...
    }
    

三、事务隔离级别

  • Isolation.DEFAULT:默认,跟随连接的数据库的隔离级别
  • 其他级别:读未提交、读已提交、可重复读、串行化

四、事务失效的情况

  1. 事务传播行为设置有问题(如nevernot_supported,以非事务方式运行)
  2. 数据库不支持事务(如使用 MyISAM 存储引擎的表)
  3. 方法的访问权限修饰符影响动态代理重写 / 调用此方法
  4. 在类的内部调用自身的方法(this调用,非动态代理对象)

五、Spring 事务传播行为(7 种)

  1. Propagation.REQUIRED(默认)
    • 若外部有事务,就加入事务;若外部没有事务,创建新事务独立运行
  2. Propagation.SUPPORTS(拥护)
    • 若已有事务,加入事务;若没有事务,以非事务处理
  3. Propagation.MANDATORY(强制的)
    • 若有事务,加入;若没有,抛出异常
  4. Propagation.REQUIRES_NEW(必须独立)
    • 若有事务,挂起当前事务,创建新事务;若没有,创建事务
  5. Propagation.NOT_SUPPORTED(不拥护)
    • 若有事务,挂起,当前方法以非事务方式运行;若没有,以非事务方式运行
  6. Propagation.NEVER(不能有事务)
    • 若有事务,抛出异常;若没有,以非事务方式运行
  7. Propagation.NESTED(嵌套)
    • 若有事务,嵌套事务运行;若没有,创建新事务
http://www.lryc.cn/news/618815.html

相关文章:

  • redis的过期策略和定时器
  • Cloud Computing(云计算)和Sky Computing(天空计算)
  • 地图可视化实践录:显示地理区域图
  • 深层神经网络
  • 测试匠谈 | AI语音合成之大模型性能优化实践
  • 【C#】用队列构建一个对象池管理对象的创建和释放
  • PySpark性能优化与多语言选型讨论
  • 各种 dp 刷题下
  • 人机交互:连接人类与数字世界的桥梁
  • apache+虚拟主机
  • 五、Elasticsearch在Linux的安装部署
  • Rust 项目编译故障排查:从 ‘onnxruntime‘ 链接失败到 ‘#![feature]‘ 工具链不兼容错误
  • 使用reqwest+select实现简单网页爬虫
  • Rust 性能提升“最后一公里”:详解 Profiling 瓶颈定位与优化|得物技术
  • open-webui源码分析1—文件上传
  • Vue接口平台十三——测试记录
  • springboot整合sharding-jdbc 5.5.2 做单库分表
  • 燕山大学计算机网络实验(2025最新)
  • Java调用Vue前端页面生成PDF文件
  • 深入剖析 React 合成事件:透过 onClick 看本质
  • Java 工厂方法模式
  • Flask + Vue.js 物联网数字大屏实现方案
  • 数据分析基本内容(第二十节课内容总结)
  • Rsync自动化备份平台建设实战
  • 【数据分析与挖掘实战】金融风控之贷款违约预测
  • 阿里云 Windows 服务器 搭建 Gitea 私有 Git 服务器完整教程
  • 开疆智能Ethernet转ModbusTCP网关连接PAC3200电能表配置案例
  • VirtualBox 虚拟机磁盘扩容完整手册
  • MaxKB+合合信息TextIn:通过API实现PDF扫描件的文档审核
  • [git] 重配ssh key | 解决冲突