码迷,mamicode.com
首页 > 其他好文 > 详细

mybatis 事务和缓存

时间:2018-02-08 15:27:21      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:开启   一个   ati   name   连接   post   作用域   nbsp   cache   

mybatis缓存介绍

一级缓存

即session缓存,作用域为 Session,当 Session flush 或 close 之后,该Session中的所有 Cache 就将清空,默认开启。

二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的

 

在业务层执行方法时,我们通常会在方法上加事务注解@Transactional,这样的话进入方法时,就会从数据库连接池拿取链接信息,建立连接,转换属性,将autoCommit设置为true,下面进行的数据库操作都在这个事务下,每次查询的结果都会以namespace的形式标识保存在缓存区域中(内存),下次如果有sql发出,就会去缓存中对比namespace,如果匹配有,就直接拿取结果返回,这就是缓存,因此我遇到的问题就是这样产生的,第一次查出来的结果保存在namespace中,我进行了修改,由于对象的操作可以认为都是通过指针(做个比喻),对对象存放位置进行了操作,即是操作了缓存区域中的对象,所以后面的查询走缓存返回的就是修改后的数据;

缓存是什么时候失效呢?在事务结束时,事务结束时就相当于执行了commit命令,sqlsession关闭,缓存失效,再进行的查询就直接发出sql,不会走缓存了

 

mybatis 事务和缓存

标签:开启   一个   ati   name   连接   post   作用域   nbsp   cache   

原文地址:https://www.cnblogs.com/lyon91/p/8431247.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!