--声明:一下内容都不一定是正确的,只是自己测试的结果,请自己的动手操作得出自己的结论
1.开启Mybatis的二级缓存,不仅要在SqlMapConfig.xml中进行开启总开关,还要在对应的XXXMapper.xml中开启,缺少其中一个二级缓存都不能开启(起不到二级缓存的作用);
2.开启Mybatis的二级缓存后,一级缓存同样起作用(相同的SqlSession一级缓存,不同的SqlSession二级缓存)
3.一级缓存,只要执行了增删改,不管有没有提交,都会清空缓存,后面如果还有相同sql的查询会将 “最新” 的数据写入到缓存中,即使该数据还没有提交,如果回滚后还是数据库的值还是回复到原来的值。这样设计并不会导致安全问题,反而更加贴近逻辑,因为一级缓存是一个SqlSession上的,不共享,这样的话,我自己做的操作,我当然希望缓存即使更新,让我后面的查询的效率提高,不用连接数据库。
4.二级缓存,当一个SqlSession调用close方法将数据放入缓存中,后面的查询才能查到数据;只有一个SqlSession执行了增删改且提交了,才会清空缓存
时间: 2024-10-24 21:45:47