mybatis 二级缓存
- mybatis的一级缓存 sqlsession
- 二级缓存的同一命名空间(namespace)mapper
mybatis 默认二级缓存未开启。内置是支持二级缓存的。但是由于本身是数据库管理组件,所以缓存并不好用,还要用第三方。典型的ehcache。
二级缓存的常见算法
- 缓存算法有:
- LRU(Least Recently Used):这种算法是在每个对象中维护一个访问的时间变量,每次访问后,时间都会更新,当新的对象需要存放到缓存时,替换那个按时间排序最后的对象。
- LFU(Least Frequently Used):这种算法是每个对象记录了对象访问的次数(即命中率),当新的对象需要存放到缓存时,替换那个访问次数最少的对象。
- FIFO(First In First Out):这种算法是将缓存中的对象存放成一个数组,当新的对象需要存放到内存中是,替换最先存放到缓存的对象。
mybatis 中开启二级缓存
- 对象要实现序列化接口Serializable
- 在mapper映射文件添加
<!-- 开启二级缓存 -->
<cache/>
- 在mybatis-config.xml文件中添加
<setting name="cacheEnabled" value="true"/>
与ehcache集成
- 导入jar包
![这里写图片描述](https://img-blog.csdn.net/20171011113307034?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvQXJyb2dhbmNlX3Fp/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
- 生成ehcache.xml配置文件
- setting中开启二级缓存
- 在mapper文件中指定cache类型为ehcache
<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>