mybatis事务不起作用,原来表引擎是MyISAM

如标题所示,事务对日志表不起作用,调试了两天,源码一直追到mysql驱动给数据库发字节码的那里,也没看出啥问题,因为数据库连接Session的autocommit一直都是false。

1590739409(1)

所以后来怀疑到数据库表本身的问题,然后通过idea的DatabaseConsole进行手动操作,事务提交设置为手动,发现日志表确实不受事务控制,从而明确了是表自身的问题,最后发现是其引擎用成了MyISAM。

但这个过程也有很多收获,比如了解了mybatis和spring的通过动态代理实现的事务控制,mybatis-plus在service、mapper上通过动态代理实现的免xml配置,以及mybatis通过动态代理实现的插件功能,在最终执行的时候就从controller开始,在一层套一层的动态代理对象之间执行。

在向数据库发送的字节码内容有完整的sql语句、提交指令和回滚指令。

Spring事务控制是通过线程上的ThreadLocal存储SqlSessionHoler实现的,同一事务将复用SqlSessionHoler中的SqlSession,从而实现多条sql语句在同一个连接session中执行,事务结束后发送一个commit命令。

image

image

由于mybatis的一级缓存是存放在SqlSession的executor中,在不启用事务的情况的情况下,每次执行查询都是新开一个SqlSession,而不是复用,导致其executor也是新的,所以一级缓存就失效了,除非多个查询在同一个事务中,这样它们就能复用同一个SqlSession了。

image

原文地址:https://www.cnblogs.com/StarkBrothers/p/12988255.html