Mybatis的二级缓存注意点
Posted 敲出一个世界
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis的二级缓存注意点相关的知识,希望对你有一定的参考价值。
--声明:一下内容都不一定是正确的,只是自己测试的结果,请自己的动手操作得出自己的结论
1.开启Mybatis的二级缓存,不仅要在SqlMapConfig.xml中进行开启总开关,还要在对应的XXXMapper.xml中开启,缺少其中一个二级缓存都不能开启(起不到二级缓存的作用);
2.开启Mybatis的二级缓存后,一级缓存同样起作用(相同的SqlSession一级缓存,不同的SqlSession二级缓存)
3.一级缓存,只要执行了增删改,不管有没有提交,都会清空缓存,后面如果还有相同sql的查询会将 “最新” 的数据写入到缓存中,即使该数据还没有提交,如果回滚后还是数据库的值还是回复到原来的值。这样设计并不会导致安全问题,反而更加贴近逻辑,因为一级缓存是一个SqlSession上的,不共享,这样的话,我自己做的操作,我当然希望缓存即使更新,让我后面的查询的效率提高,不用连接数据库。
4.二级缓存,当一个SqlSession调用close方法将数据放入缓存中,后面的查询才能查到数据;只有一个SqlSession执行了增删改且提交了,才会清空缓存
以上是关于Mybatis的二级缓存注意点的主要内容,如果未能解决你的问题,请参考以下文章
mybatis缓存,包含一级缓存与二级缓存,包括ehcache二级缓存
Mybatis从入门到精通系列 12——Mybatis 的一级缓存与二级缓存