mybatis设置mysql引擎_mybatis事务不起作用,原来表引擎是MyISAM

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

86b17565faad9c9323504d7a1cb329f7.png

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

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

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

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

e967b4e4ecb7dfe992f5d12a8ace831e.png

363c41401bff3d527623bfeb27db20b2.png

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

43c78fe33ab1f120209a3427eaa9b35c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值