MyBatis 缓存与 Spring 事务相关笔记

一、MyBatis 缓存

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

二、Spring 事务实现方式

  1. 编程式事务

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

    • 通过@Transactional注解实现
    • 示例代码:
    java 复制代码
    @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(嵌套)
    • 若有事务,嵌套事务运行;若没有,创建新事务
相关推荐
Mr_Xuhhh6 分钟前
MySQL函数详解:日期、字符串、数学及其他常用函数
java·数据库·sql
测试开发Kevin1 小时前
小tip:换行符CRLF 和 LF 的区别以及二者在实际项目中的影响
java·开发语言·python
笨手笨脚の1 小时前
Redis: Thread limit exceeded replacing blocked worker
java·redis·forkjoin·thread limit
Lenyiin1 小时前
Linux 基础IO
java·linux·服务器
松☆2 小时前
Dart 核心语法精讲:从空安全到流程控制(3)
android·java·开发语言
编码者卢布2 小时前
【App Service】Java应用上传文件功能部署在App Service Windows上报错 413 Payload Too Large
java·开发语言·windows
q行3 小时前
Spring概述(含单例设计模式和工厂设计模式)
java·spring
好好研究3 小时前
SpringBoot扩展SpringMVC
java·spring boot·spring·servlet·filter·listener
毕设源码-郭学长3 小时前
【开题答辩全过程】以 高校项目团队管理网站为例,包含答辩的问题和答案
java