查询缓存

Posted tunan-ki

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查询缓存相关的知识,希望对你有一定的参考价值。

将上一次的查询结果保存在内存中,后面如果是相同的查询,就不再去数据库查询,到内存中获取数据。如果中间进行了增、删、改,需要清空缓存中的数据。

好处:

提高查询速度,减小数据库服务器压力

Mybatis中的查询缓存:

一级查询缓存

如果使用的是同一个SqlSession对象中【没有被关闭过close()】,执行了多次相同的查询语句,第一次查询后会将结果保存到内存中,后面相同的查询会从内存中直接获取数据,而不再去数据中查询,提高查询速度。

当一个SqlSession对象被关闭后,该SqlSession的上一次查询结果缓存中就不存在了。

Mybatis中一级缓存默认就是开启状态,不需要手动启动,而且不能够进行关闭。

一级缓存的验证:

用同一个SqlSession对象执行相同的方法,控制台只有一次查询

技术图片

 

 

控制台

技术图片

 

 

如果使用的不同的SqlSession对象,那么不使用缓存

技术图片

 

 

如果使用的是同一个SqlSession对象,但是中间出现了增删改操作,缓存也不起作用

技术图片

 

 

结果

技术图片

 

 

二级查询缓存

二级缓存与一级缓存,一级缓存当SqlSession关闭,则缓存数据不再存在,二级缓存的缓存数据与SqlSession对象无关。二级缓存延长缓存数据的保存时间。

使用

对查询语句中涉及到的实体类必须实现序列化接口

技术图片

 

 

在对应的映射文件中的mapper标签中添加cache子标签

技术图片

 

 

验证二级缓存的作用

使用的是不同的SqlSession对象

技术图片

 

 

执行结果

技术图片

 

 验证增删改对二级缓存的影响

技术图片

 

 

二级缓存在有增删改的时候会自动清空缓存,到数据库查找。

以上是关于查询缓存的主要内容,如果未能解决你的问题,请参考以下文章

笔记:Hibernate 查询缓存

12.查询缓存

MySQL查询缓存

MySQL进阶实战11,查询缓存

Mysql 查询缓存利弊

hibernate 一级缓存,二级缓存,查询缓存