将上一次的查询结果保存在内存中,后面如果是相同的查询,就不再去数据库查询,到内存中获取数据。如果中间进行了增、删、改,需要清空缓存中的数据。
好处:
提高查询速度,减小数据库服务器压力
Mybatis中的查询缓存:
一级查询缓存
如果使用的是同一个SqlSession对象中【没有被关闭过close()】,执行了多次相同的查询语句,第一次查询后会将结果保存到内存中,后面相同的查询会从内存中直接获取数据,而不再去数据中查询,提高查询速度。
当一个SqlSession对象被关闭后,该SqlSession的上一次查询结果缓存中就不存在了。
Mybatis中一级缓存默认就是开启状态,不需要手动启动,而且不能够进行关闭。
一级缓存的验证:
用同一个SqlSession对象执行相同的方法,控制台只有一次查询
控制台
如果使用的不同的SqlSession对象,那么不使用缓存
如果使用的是同一个SqlSession对象,但是中间出现了增删改操作,缓存也不起作用
结果
二级查询缓存
二级缓存与一级缓存,一级缓存当SqlSession关闭,则缓存数据不再存在,二级缓存的缓存数据与SqlSession对象无关。二级缓存延长缓存数据的保存时间。
使用
对查询语句中涉及到的实体类必须实现序列化接口
在对应的映射文件中的mapper标签中添加cache子标签
验证二级缓存的作用
使用的是不同的SqlSession对象
执行结果
验证增删改对二级缓存的影响
二级缓存在有增删改的时候会自动清空缓存,到数据库查找。