mybatis学习笔记(6) ------ 缓存

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/weixin_43213517/article/details/99707239

mybatis学习笔记(6) ------ 缓存

缓存

缓存就是暂存数据的地方,mybatis提供缓存机制,将数据存储在缓存中,下次查询的时候,若缓存中存在需要的数据,就无需去数据库中查找,可以提升性能。

一级缓存

在SqlSession中维护一个缓存,用来用来存放查找出来的数据,因此一级缓存只在同一个SqlSession对象中有效,不同的SqlSession都有属于自己的HashMap,都有属于自己的缓存。当调用commit方法之后,缓存会被清空。

演示

 @Test
    public void test8(){
        SqlSession sqlSession = factory.openSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User u1 = mapper.search(1);
        System.out.println(u1);
        System.out.println("=================");
        //sqlSession.commit();
        User u2 = mapper.search(1);
        System.out.println(u2);
    }

第一次会执行sql语句,第二次不会执行sql语句,直接从缓存中获取。但当注释解开之后,则第二次也会执行sql语句。
在这里插入图片描述

注: 当select元素中将flushCache设置为true后,也会刷新缓存,这个值默认是false。

二级缓存

  • 需要手动开启缓存
        <!--开启二级缓存总开关,默认为true-->
        <setting name="cacheEnabled" value="true"/>
  • 对应的映射文件中开启缓存,在select标签中开启缓存
 <cache/>
 useCache="true" : 默认为true,只与二级缓存有关
  • 主配置文件中开启二级缓存

多个SqlSession共用一个SqlSessionFactory
当sqlSession执行close方法,就会将查询的内容存入二级缓存中,下一次不同的sqlSession可以直接去缓存中找数据,找不到再去数据库中查。
每一次增删改之后,都会刷新缓存,一二级缓存都会被刷新。

猜你喜欢

转载自blog.csdn.net/weixin_43213517/article/details/99707239