• MyBatis缓存


    为什么使用缓存?

    经常查询一些不经常发生变化的数据,使用缓存来提高查询效率。

    Mybatis中缓存分为一级缓存,二级缓存。

    1.一级缓存

    一级缓存是SqlSession级别的缓存,是默认开启的。

    在参数和SQL语句完全相同的情况下,

    使用SqlSession对象调用一个Mapper方法,

    1. InputStream resource = Resources.getResourceAsStream("SqlMapConfig.xml");
    2. SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(resource);
    3. SqlSession sqlSession = factory.openSession();
    4. UserMapper mapper = sqlSession.getMapper(UserMapper.class);

    然后通过Mapper方法调用你编写的查询方法,不论你调用几次查询方法

    1. User userById = mapper.findUserById(1);
    2. System.out.println("====第一次查询====:" + userById);
    3. User userById1 = mapper.findUserById(1);
    4. System.out.println("====第二次查询====:" + userById1);

    程序只会执行一次SQL(即向数据库发送一次SQL请求),因为在使用SqlSession进行第一次查询后,Mybatis就会将其放入缓存中,当你后续再调用查询方法时,如果没有声明需要刷新缓存没有超时的情况下,SqlSession都会取出缓存的数据,而不会再次发送SQL请求到数据库,这样就提高了效率。

    一级缓存是SqlSession范围的缓存,执行SqlSession的增、删、改操作,或者调用clearCache()、commit()、close()方法,都会清空缓存

    清除缓存的方法

    1.

    1. //调用sqlSession清除缓存的方法
    2. sqlSession.clearCache();

    2.

    1. <!-- 每次查询时,都会清除缓存 -->
    2. < select flushCache="true"></select>

    2.二级缓存

    二级缓存是namspace级别(跨sqlSession)的缓存,是默认不开启的

    二级缓存的开启需要进行配置,实现二级缓存的时候,MyBatis要求返回的POJO必须是可序列化的。
    也就是要求实现Serializable接口,配置方法很简单,

    SqlMapConfig.xml

    1. <!-- 因为cacheEnabled的取值默认就为true,所以这一步可以省略不配置。
    2. 为true代表开启二级缓存;为false代表不开启二级缓存。
    3. -->
    4. <setting name="cacheEnabled" value="true"/>

    UserMapper.xml

    1. <!-- 开启二级缓存-->
    2. <cache/>
    3. <!-- 查询所有订单 及对应的用户信息-->
    4. <!-- 在标签中设置useCache=“true” 表示当前statement 要使用二级缓存
    5. 如果不用 可以设置为false
    6. -->
    7. <select id="findUserById" parameterType="int" resultType="com.qiku.popo.User" useCache="true">
    8. select * from user where id = #{id}
    9. </select>

    还有你的实体类中要继承

    Serializable 接口
    
    1. public class User implements Serializable {
    2. 。。。。。。。
    3. }

    在你测试代码中执行完代码后,要加入下面两句中的任意一句

    1. sqlSession1.close();//将结果存入二级缓存
    2. sqlSession1.commit();

    除了第一个方法可以省略外,剩下一定要写

  • 相关阅读:
    Java面向对象2
    用Python计算点估计预测评价指标(误差指标RMSE、MSE、MAE、MAPE) ,画图展示
    SpringSecurity Oauth2实战 - 06 拦截器获取用户登录信息并存储到本地线程ThreadLocal
    【Redis】聊一下Redis事务以及watch机制
    面试打底稿⑤ 项目一的第一部分
    【附源码】Python计算机毕业设计某企业的采购管理系统优化设计
    LinkSLA坚持用户第一,打造可持续的运维服务方案
    编译锐尔科技A33开发板, openssl报错
    短信的信令过程
    Leetcode刷题day1|数组一|704.二分查找,27.移除元素,35.搜索插入位置
  • 原文地址:https://blog.csdn.net/chaochaodayizhi/article/details/125416862