mybatis缓存
mybatis支持缓存,如果我们查找数据库中某一条记录时,先从缓存中获取,如果缓存中不存在该记录,则从数据库中获取,在放入到缓存中。
mybatis 存在两种缓存:一级缓存 二级缓存
缓存的访问顺序:二级缓存 一级缓存 数据库
一级缓存:
基于sqlsession级别的缓存,该缓存无法关闭,但会失效。
一级缓存失效的四种情况:
1.不同的SqlSession对应不同的一级缓存
2.同一个SqlSession但是查询条件不同
3.同一个SqlSession两次查询期间执行了任何一次增删改操作
4.同一个SqlSession两次查询期间手动清空了缓存
二级缓存:
基于namespace级别的缓存.就是当sqlSession被关闭后,会把sqlSession中的内容放入到二级缓存中.(必须关不sqlSession后二级缓存中才会有内容.
-
开启二级缓存
在配置文件中加入 -
在相关的映射文件中使用二级缓存
eviction:缓存回收策略
LRU:最近最少用
FIFO:先进先出
flushInterval:刷新间隔
size:设置环村的最大个数
readOnly:只读
3. 查询的实体类必须实现Serializable序列化接口。
public class 类名 implements Serializable{ }
映射文件中的顺序:
properties:引入属性文件
settings:环境配置
typeAliases:别名
typeHandlers:类型处理
objectFactory:对象工厂
objectWrapperFactory:对象包装工厂
reflectorFactory:反射工厂
plugins:插件
environments:
databaseldProvider:数据库
mapper :
如果出现Caused by: org.xml.sax.SAXParseException; lineNumber: 50; columnNumber: 17; 元素类型为 “configuration” 的内容必须匹配 "错误,
说明主配置文件中的顺序没有按照上述顺序写
二级缓存的优化:
1.下载第三方缓存的jar包(EHcache)
ehcache-core-2.6.8.jar
2.mybatis与ehcache适配器的jar
mybatis-ehcache-1.0.3.jar
slf4j-api-1.6.1.jar
slf4j-log4j12-1.6.2.jar
3.需要在相应的mapper里的cache标签上添加
type=” org.mybatis.caches.ehcache.EhcacheCache”
4. 加入cache.xml文件.
<defaultCache
maxElementsInMemory="1"
maxElementsOnDisk="10000000"
eternal="false"
overflowToDisk="true"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
</defaultCache>
属性说明:
l diskStore:指定数据在磁盘中的存储位置。
l defaultCache:当借助CacheManager.add("demoCache")创建Cache时,EhCache便会采用指定的的管理策略
以下属性是必须的:
l maxElementsInMemory - 在内存中缓存的element的最大数目
l maxElementsOnDisk - 在磁盘上缓存的element的最大数目,若是0表示无穷大
l eternal - 设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,如果为false那么还要根据timeToIdleSeconds,timeToLiveSeconds判断
l overflowToDisk - 设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上
以下属性是可选的:
l timeToIdleSeconds - 当缓存在EhCache中的数据前后两次访问的时间超过timeToIdleSeconds的属性取值时,这些数据便会删除,默认值是0,也就是可闲置时间无穷大
l timeToLiveSeconds - 缓存element的有效生命期,默认是0.,也就是element存活时间无穷大
diskSpoolBufferSizeMB 这个参数设置DiskStore(磁盘缓存)的缓存区大小.默认是30MB.每个Cache都应该有自己的一个缓冲区.
l diskPersistent - 在VM重启的时候是否启用磁盘保存EhCache中的数据,默认是false。
l diskExpiryThreadIntervalSeconds - 磁盘缓存的清理线程运行间隔,默认是120秒。每个120s,相应的线程会进行一次EhCache中数据的清理工作
l memoryStoreEvictionPolicy - 当内存缓存达到最大,有新的element加入的时候, 移除缓存中element的策略。默认是LRU(最近最少使用),可选的有LFU(最不常使用)和FIFO(先进先出)