缓存
Mybatis的一级缓存:
Mybatis的一级缓存是SqlSession级别的,即通过同一个SqlSession查询的数据会被缓存,再次使用同一个SqlSession查询同一条数据,会从缓存中获取。
使一级缓存失效的四种情况:
1)不同的SqlSession对应不同的一级缓存
2)同一个SqlSession但是查询条件不同
3)同一个SqlSession两次查询期间执行了任何一次增删改操作
4)同一个SqlSession两次查询期间手动清空了缓存
Mybatis的二级缓存:
Mybatis的二级缓存是SqlSessionFactory级别的,即通过同一个SqlSessionFactory所获取的SqlSessionFactory对象
查询的数据会被缓存,在通过同一个SqlSessionFactory所获取的SqlSession查询相同的数据会从缓存中获取
Mybatis二级缓存开启的条件:
1)在核心配置文件中,设置全局配置属性cacheEnabled=“true”,默认为true,不需要设置
2)在映射文件中设置标签
3)二级缓存必须在SQLSession关闭或提交之后有效
4)查询的数据所转换的实体类类型必须实现序列化的接口
缓存查询顺序:
先查询二级缓存——>再查询一级缓存——>最后查询数据库
注意:
SqlSession被关闭后,一级缓存会存入二级缓存
第三方缓存:
以EHCache为例
1)向pom.xml文件中导入EHCache依赖
<!--Mybatis EHCache整合包-->
<dependency>
<groupId>org.mybatis.caches</groupId>
<artifactId>mybatis-ehcache</artifactId>
<version>1.2.1</version>
</dependency>
2)在resources中创建ehcache.xml文件
<?xml version="1.0" encoding="utf-8" ?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
<!-- 磁盘保存路径 -->
<!--
maxElementsInMemory:必须设置,在内存中缓存的element的最大数目
maxElementsOnDisk:必须设置,在磁盘上缓存的element的最大数目,若是0表示无穷大
eternal:必须设置,设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,
如果为false那么还要根据timeToIdleSeconds、timeToLiveSeconds判断
overflowToDisk :必须设置,设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上
timeToIdleSeconds :当缓存在EhCache中的数据前后两次访问的时间超过timeToIdleSeconds的属性取值时,
这些数据便会删除,默认值是0,也就是可闲置时间无穷大
timeToLiveSeconds:缓存element的有效生命期,默认是0.,也就是element存活时间无穷大
diskSpoolBufferSizeMB:DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区
diskPersistent :在VM重启的时候是否启用磁盘保存EhCache中的数据,默认是false
diskExpiryThreadIntervalSeconds :磁盘缓存的清理线程运行间隔,默认是120秒。
每个120s, 相应的线程会进行一次EhCache中数据的清理工作
memoryStoreEvictionPolicy:当内存缓存达到最大,有新的element加入的时候, 移除缓存中element的策略。
默认是LRU (最近最少使用),可选的有LFU (最不常使用)和FIFO (先进先出)
-->
<diskStore path="E:\StudyFile\agentp\ehcache"/>
<defaultCache
maxElementsInMemory="1000"
maxElementsOnDisk="10000000"
eternal="false"
overflowToDisk="true"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
</defaultCache>
</ehcache>