Mybatis缓存

MyBatis一级缓存

        Mybatis对缓存提供支持,但是在没有配置的默认情况下,它只开启一级缓存,一级缓存只是相对于同一个 SqlSession 而言。所以在参数和SQL完全一样的情况下,我们使用同一个SqlSession对象调用一个Mapper方法,往往只执行一次SQL,因为使用SelSession第一次查询后,MyBatis会将其放在缓存中,以后再查询的时候,如果没有声明需要刷新,并且缓存没有超时的情况下,SqlSession都会取出当前缓存的数据,而不会再次发送SQL到数据库。

MyBatis二级缓存

        MyBatis的二级缓存是Application级别的缓存,它可以提高对数据库查询的效率,以提高应用的性能。

开启二级缓存

        SqlSessionFactory层面上的二级缓存默认是不开启的,二级缓存的开启需要进行配置,实现二级缓存的时候,MyBatis要求返回的POJO必须是可序列化的。 也就是要求实现Serializable接口,配置方法很简单,只需要在映射XML文件配置就可以开启缓存了。

Mybatis开启使用二级缓存

        修改配置文件mybatis-config.xml加入

        在mapper.xml中开启二缓存,mapper.xml下的sql执行完成会存储到它的缓存区


参数说明:
eviction:
        LRU 最近最少使用的:移除最长时间不被使用的对象
        FIFO  先进先出:按对象进入缓存的顺序来移除它们
        SOFT 软引用:移除基于垃圾回收器状态和软引用规则的对象
        WEAK 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象
flushInterval :刷新间隔)可以被设置为任意的正整数,而且它们代表一个合理的毫秒形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新(mia毫秒单位)
size :引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的可用内存资源数目。默认值是1024
readOnly :(只读)属性可以被设置为true或false。只读的缓存会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。可读写的缓存会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是false

select,insert,update标签中的缓存属性

useCache=false,禁用二级缓存
flushCache=true 刷新缓存 ,一般用于insert,update

你可能感兴趣的:(mybatis,mybatis,缓存,oracle)