事务传播行为----PROPAGATION_REQUIRED
SpringBoot整合Mybatis,Sql语句的执行情况没有打日志,所以增加了如下配置:
logback-spring.xml
<!--myibatis log configure-->
<logger name="com.apache.ibatis" level="DEBUG"/>
<logger name="java.sql.Connection" level="DEBUG"/>
<logger name="java.sql.Statement" level="DEBUG"/>
<logger name="java.sql.PreparedStatement" level="DEBUG"/>
application.yml
mybatis:
type-aliases-package: com.liu.entity
logging:
config: classpath:logback-spring.xml
(Spring Boot默认使用的是logback日志框架)由于日志级别设置成了debug,内容释放详细,就顺便研究了下spirng的事务。
1.单个事务方法执行
从日志中可以看出,Spring 默认的事务传播行为为PROPAGATION_REQUIRED,事务隔离级别为ISOLATION_DEFAULT,这个标识对应到Mysql数据库的事务隔离级别为Repeatable read(可重复读取)。
sql执行情况:创建事务》获取JDBC连接》执行sql》提交事务》释放JDBC连接》将连接返回连接池
2.业务层两个事务方法间的相互调用,事务传播行为为PROPAGATION_REQUIRED
delete和update使用了同一个事务,PROPAGATION_REQUIRED:表示该方法必须在事务中执行,若当前存在事务,则在该事务中执行,若没有事务,则开启一个新事务。
3.一个类中,方法A没有事务,方法B有事务,A调用B,外部调用A,B的事务不会生效的
delete的事务没有生效
原因:A调用B的时候,使用的是当前实例对象调用的,基于AOP的事务需要通过代理对象调用,事务才能生效
解决办法:在类里注入本身自己的bean,通过这个bean调用delete,事务就可以生效。
执行日志如下:
执行delete的时候开启了一个新事务,事务生效。
4.@Transactional作用在私有private方法上不生效,项目启动的时候,会遍历所有加了@Transactional注解的方法,若方法为私有的,则返回Null,注解不生效