mybatis 二级缓存

mybatis 二级缓存

  1. mybatis的一级缓存 sqlsession
  2. 二级缓存的同一命名空间(namespace)mapper

mybatis 默认二级缓存未开启。内置是支持二级缓存的。但是由于本身是数据库管理组件,所以缓存并不好用,还要用第三方。典型的ehcache。

二级缓存的常见算法

  • 缓存算法有:
    1. LRU(Least Recently Used):这种算法是在每个对象中维护一个访问的时间变量,每次访问后,时间都会更新,当新的对象需要存放到缓存时,替换那个按时间排序最后的对象。
    2. LFU(Least Frequently Used):这种算法是每个对象记录了对象访问的次数(即命中率),当新的对象需要存放到缓存时,替换那个访问次数最少的对象。
    3. FIFO(First In First Out):这种算法是将缓存中的对象存放成一个数组,当新的对象需要存放到内存中是,替换最先存放到缓存的对象。

mybatis 中开启二级缓存

  1. 对象要实现序列化接口Serializable
  2. 在mapper映射文件添加


  3. 在mybatis-config.xml文件中添加

<setting name="cacheEnabled" value="true"/>

与ehcache集成

  1. 导入jar包
    这里写图片描述
  2. 生成ehcache.xml配置文件
  3. setting中开启二级缓存
  4. 在mapper文件中指定cache类型为ehcache

<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

你可能感兴趣的:(mybatis 二级缓存)