2.13 Mybatis——缓存策略

本文详细介绍了MyBatis的缓存机制,包括一级缓存SqlSession和二级缓存SqlSessionFactory的区别。二级缓存是全局共享的,可以在多个SqlSession之间复用。开启二级缓存的步骤包括在映射文件中配置缓存属性,然后在全局配置文件中开启缓存开关。此外,还展示了如何在特定方法中关闭二级缓存。在实际应用中,合理使用二级缓存能有效提升数据库查询效率。
摘要由CSDN通过智能技术生成

1. 缓存种类

一级缓存 SqlSession缓存默认开启)

        SqlSession关闭后(sqlSession.close()),缓存消失。

二级缓存 SqlSessionFactory缓存

        当二级缓存开启后,同一个命名空间(namespace) 所有的操作语句,都影响着一个共同的 cache,也就是二级缓存被多个 SqlSession 共享,是一个全局的变量。当开启缓存后,数据的查询执行的流程就是 二级缓存 -> 一级缓存 -> 数据库。

2. 二级缓存的开启

第一步:在映射文件中追加二级缓存配置

<cache eviction="LRU" flushInterval="100000" readOnly="true" size="1024"/>
<!--开启本mapper的namespace下的二级缓存-->
    <!--
        eviction:代表的是缓存回收策略,目前MyBatis提供以下策略。
        (1) LRU,最近最少使用的,一处最长时间不用的对象
        (2) FIFO,先进先出,按对象进入缓存的顺序来移除他们
        (3) SOFT,软引用,移除基于垃圾回收器状态和软引用规则的对象
        (4) WEAK,弱引用,更积极的移除基于垃圾收集器状态和弱引用规则的对象。
这里采用的是LRU, 移除最长时间不用的对形象
        flushInterval:刷新间隔时间,单位为毫秒,这里配置的是100秒刷新,如果你
不配置它,那么当SQL被执行的时候才会去刷新缓存。
        size:引用数目,一个正整数,代表缓存最多可以存储多少个对象,不宜设置过
大。设置过大会导致内存溢出。这里配置的是1024个对象
        readOnly:只读,意味着缓存数据只能读取而不能修改,这样设置的好处是我们
可以快速读取缓存,缺点是我们没有办法修改缓存,他的默认值是false,不允许我们修改
    -->

第二步:在mybatis-config.xml的配置文件中开启二级缓存开关

新版本默认已经开启,不需要配置

<!-- 通知 MyBatis 框架开启二级缓存 -->
<settings> 
    <setting name="cacheEnabled" value="true"/>
</settings>

第三步:如果某些方法不想使用二级缓存,在方法中的select标签中可以设置关闭二级缓存。

useCache="false"

3.效果展示

 @Test
    public void selectUser() throws IOException {

        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
        
        /*********************查询第一次*******************************/
        SqlSession sqlSession = sqlSessionFactory.openSession();
        UserDao mapper = sqlSession.getMapper(UserDao.class);
        List<User> users = mapper.selectUser();
        System.out.println(users);
        sqlSession.commit();
        sqlSession.close();
        /************************************************************/
        
         /*********************查询第二次*******************************/
        SqlSession sqlSession1= sqlSessionFactory.openSession();
        /**********************方式一***********************/
        //通过SqlSession获取XXXDao
        UserDao mapper1= sqlSession1.getMapper(UserDao.class);
        //查询所有用户
        List<User> users1 = mapper1.selectUser();
        System.out.println(users1);
        /****************************************************/

    }

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值