什么是查询缓存?
查询缓存顾名思义,就是与增删改毫无关系,只有在查询时才用到的缓存,增删改不涉及缓存。
查询缓存分为:一级缓存与二级缓存
一级缓存
范围:同一个SqlSession对象
如果用同一个SqlSession对象查询相同的数据,则只会在第一次查询时向数据库发送SQL语句(访问了一次数据库);并将查询的结果 放入到SqlSession对象中(作为缓存存在);后续再次查询该同样的对象时,则直接从缓存中查询该对象即可(即省略了数据库的访问),这样可以提高性能。
第一次查询信息,是从数据库中获取指定的信息,然后将查到的信息放入到SqlSession对象中去(SqlSession对象在内存之中);第N次查询第一次查询到的信息,不需要再从数据库中获取信息,而是直接从缓存中获取(Sqlsession对象中)
提交commit();方法,就会将缓存中的对象全部清空。(就是从SqlSession中移除)
二级缓存
Mybatis自带二级缓存:
范围:同一个namespace生成的mapper对象
namespace的值就是接口的全类名(包名.类名),通过接口可以产生代理对象。
第三方提供的二级缓存:
ehcache、memcache…(这两个厂商已经实现过了Cache接口)
要想整合第三方提供的二级缓存(或者自定义二级缓存),必须实现Cache接口(mybatis提供的接口),该接口的默认实现类是PerpetualCache
整合ehcache二级缓存
1、需要jar包
Ehcache-core.jar
mybatis-Ehcache.jar
slf4j-api.jar
2、在src下编写ehcache配置文件(Ehcache.xml)
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">