关于Mybatis的二级缓存

定义

二级缓存是 mapper 映射级别或者说是Mybatis中SqlSessionFactory对象的缓存,多个 SqlSession 去操作同一个 Mapper 映射的 sql 语句,多个SqlSession 可以共用二级缓存,二级缓存是跨 SqlSession 的。

二级缓存结构图

在这里插入图片描述

执行过程:
1.开启 mybatis 的二级缓存。sqlSession1 去查询用户信息,查询到用户信息会将查询数据存储到二级缓存中。
2.sqlSession2 去查询与 sqlSession1 相同的用户信息,首先会去缓存中找是否存在数据,如果存在直接从
缓存中取出数据。
3.如果 SqlSession3 去执行相同 mapper 映射下 sql,执行 commit 提交,将会清空该 mapper 映射下的二
级缓存区域的数据。

二级缓存的使用

一、开启二级缓存

在我们的主配置文件中的setting标签下添加一句话

 <!--设置二级缓存的打开与否 默认值就是true-->
        <setting name="cacheEnabled" value="true"/>

二、配置相关的 Mapper 映射文件

在mapper配置文件中

<mapper namespace="com.tubai.dao.UserDao">
    <!--
        设置 useCache=”true”代表当前这个 statement 要使用
        二级缓存,如果不使用二级缓存可以设置为 false。
        注意:如果是每次查询都需要最新的数据的sql语句,要设置成 useCache=false,禁用二级缓存。
    -->
    <select id="findUserByID" parameterType="Integer" resultType="com.tubai.domain.User"
    useCache="true">
        select * from user where id = #{uid}
    </select>
    <!--
        <cache>标签表示当前这个 mapper 映射将使用二级缓存,
        区分的标准就看 mapper 的 namespace 值。
    -->
    <cache/>
</mapper>

添加一个名为cache的标签
并且在要使用二级缓存的标签处添加一个名为useCache的属性

测试二级缓存

private InputStream is;
    private SqlSession sqlSession;
    private UserDao userDao;
    private SqlSessionFactory factory;

    @Before//用于在测试方法执行之前执行
    public void init()throws Exception{
        is = Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        factory = builder.build(is);
    }
    @After//用于在测试方法运行之后执行
    public void close()throws Exception{
        is.close();
    }

    /**
     * 测试二级缓存
     */
    @Test
    public void testSecondLevelCache(){
        SqlSession sqlSession1 = factory.openSession();
        userDao = sqlSession1.getMapper(UserDao.class);
        User user1 = userDao.findUserByID(41);
        System.out.println(user1);
        sqlSession1.close();

        SqlSession sqlSession2 = factory.openSession();
        userDao = sqlSession2.getMapper(UserDao.class);
        User user2 = userDao.findUserByID(41);
        System.out.println(user2);
        sqlSession2.close();
        System.out.println(user1==user2);
    }

运行结果:
在这里插入图片描述

在这里插入图片描述

我们发现二级缓存已经起作用了 但是我们发现这两个user并不是同一个,因为二级缓存中存储的是单纯的数据 而不是对象
因此 虽然两个user的各个属性一样 但他们是两个对象.

结论

经过上面的测试,我们发现执行了两次查询,并且在执行第一次查询后,我们关闭了一级缓存,再去执行第二次查询时,我们发现并没有对数据库发出 sql 语句,所以此时的数据就只能是来自于我们所说的二级缓存。

注意事项

当我们在使用二级缓存时,所缓存的类一定要实现 java.io.Serializable 接口,这种就可以使用序列化
方式来保存对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值