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