mybatis缓存配置

使用缓存可以使应用更快地获取数据,避免频繁的数据库交互,尤其是在查询越多、缓存命中率越高的情况下,使用缓存的作用就越明显。mybatis作为持久化框架,提供了非常强大的查询缓存特性,可以非常方便地配置和定制使用。

 一般提到mybatis缓存的时候,都是指二级缓存。一级缓存(也叫本地缓存)默认会启用,并且不能控制。

一级缓存:

   mybatis的一级缓存存在于sqlSession的生命周期中,在同一个sqlSession中查询时,Mybatis会把执行的方法和参数通过算法生成缓存的键值,将键值和查询结果存入一个map对象中。如果同一个sqlSession中执行的方法和参数完全一致,那么通过算法会生成相同的键值,当map缓存对象中已经存在该键值时,则会返回缓存中的对象。

  如果在方法上增加了flushCache = "true" 会在查询数据前清空当前的一级缓存,因此该方法每次都会重新从数据库中查询数据。

  如果在sqlSession生命周期中,执行了任何的insert、update、delete操作都会清空一级缓存

二级缓存:

  mybatis的二级缓存非常强大,它不同于一级缓存只存在于sqlSession的生命周期中,而是可以理解为存在于sqlSessionFactory的生命周期中。如果是redis这样的缓存数据库时,就算应用关闭,缓存数据依然存在。

在mybatis的全局配置settings中有一个参数 cacheEnabled,这个参数是二级缓存的全局开关,默认值是true,初始化状态为启用状态。如果把这个参数设置为false,即使有后面的二级缓存配置,也不会生效。由于这个参数值默认为true,所以不必配置,如果想要配置,可以在mybatis-config.xml中添加如下代码。

<settings>

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

</settings>

mybatis的二级缓存是和命名空间绑定的,即二级缓存需要配置在Mapper.xml映射文件中,或者配置在Mapper.java接口中。在映射文件中,命名空间就是xml根节点mapper的namespace属性。在mapper接口中,命名空间就是接口的全限定名称。

mapper.xml中配置二级缓存

在保证二级缓存的全局配置开启的情况下,给UserMapper.xml开启二级缓存只需要在UserMapper.xml中添加<cache/>元素即可,添加后的UserMapper.xml如下。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
               "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="tk.mybatis.simple.mapper.UserMapper">
   <cache/>

<!--其他配置-->

默认的二级缓存会有如下效果。

一、 映射语句文件中的所有select语句将会被缓存。

二、映射语句文件中的所有insert、update、delete语句会刷新缓存。

三、缓存会使用least Recently Used(LRU、最近最少使用的)算法来收回。

四、根据时间表(如 no flush interval ,没有刷新间隔)、缓存不会以任何时间顺序来刷新。

五、缓存会存储集合或对象的1024个引用

六、缓存会被视为read/write(可读/可写)的,意味着对象检索不是共享的,而且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。

所有的这些属性都可以通过缓存元素的属性来修改,示例如下。

<cache  eviction="FIFO"  flushInterval="60000" size="512" readOnly="true"/>

这个更高级的配置创建了一个FIFO缓存,并且每隔60秒刷新一次,存储集合或对象的512个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改它们会导致冲突。cache可以配置的属性如下:

 eviction(收回策略)

    LRU(最近最少使用的):移除最长时间不被使用的对象,这是默认值。

   FIFO(先进先出):按对象进入缓存的顺序来移除它们。

   SOFT(软引用):移除基于垃圾回收器状态和软引用规则的对象。

   WEAK(弱引用):更积极地移除基于垃圾收集器状态和弱引用规则的对象。

   flushInterval(刷新间隔)。可以被设置为任意的正整数,而且它们代表一个合理的毫秒形式的时间段。默认情况不设置,即没有刷新间隔,缓存仅仅在调用语句时刷新。

   size(引用数目)。可以被设置为任意正整数,要记住缓存的对象数目和运行环境的可用内存资源数目。默认值是1024。

   readOnly(只读)。属性可以被设置为true或false。只读的缓存会给所有调用者返回缓存对象的相同实例,因此这些对象不能被修改,这提供了很重要的性能优势。可读写的缓存会通过序列化返回对象的拷贝,这种方式会慢一些,但是安全,因此默认是false。

 

mapper接口中配置二级缓存

在使用注解方式时,如果想对注解方法启用二级缓存,需要在Mapper接口中进行配置。

@CacheNamespace(

   eviction = FifoCache.class,

   flushInterval = 60000,

   size=512,

   readWrite=true

)

public interface RoleMapper{

   //接口方法

}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值