zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    模板之导入include
    模板之继承
    jQuery ajax简单用法
    Django 路由系统URL
    Django 的简单使用
    python selenium web自动化的三种等待的区别
    Django的数据库介绍
    Django 安装与介绍
    插件轮播
    bootstrap 简单使用(实现图标和按钮下拉)
  • 原文地址:https://www.cnblogs.com/StarkBrothers/p/12988255.html
Copyright © 2011-2022 走看看