ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Mybatis----缓存

2020-02-29 21:41:27  阅读:218  来源: 互联网

标签:缓存 SqlSession 用户 二级缓存 Mybatis 查询


Mybatis 缓存

像大多数的持久化框架一样, Mybatis 也提供了缓存策略,通过缓存策略来减少数据库的查询次数, 从而提高性能。
Mybatis 中缓存分为一级缓存,二级缓存
在这里插入图片描述

  • 什么是缓存: 存在于内存中的临时数据。
  • 什么样的数据能使用缓存,什么样的数据不能使用
  • 适用于缓存:
    经常查询并且不经常改变的。
    数据的正确与否对最终结果影响不大的。
  • 不适用于缓存:
    经常改变的数据
    数据的正确与否对最终结果影响很大的。
    例如:商品的库存,银行的汇率,股市的牌价。

Mybatis 一级缓存

  • 它指的是Mybatis中SqlSession对象的缓存。
  • 当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。
  • 该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中
  • 查询是否有,有的话直接拿出来用。
  • 当SqlSession对象消失时,mybatis的一级缓存也就消失了。

一级缓存的分析

一级缓存是 SqlSession 范围的缓存,当调用 SqlSession 的修改,添加,删除, commit(), close()等方法时,就会清空一级缓存。
在这里插入图片描述

  • 第一次发起查询用户 id 为 1 的用户信息,先去找缓存中是否有 id 为 1 的用户信息,如果没有,从数据库查询用户信息。
  • 得到用户信息,将用户信息存储到一级缓存中。
  • 如果 sqlSession 去执行 commit 操作(执行插入、更新、删除),清空 SqlSession 中的一级缓存,这样做的目的为了让缓存中存储的是最新的信息,避免脏读。
  • 第二次发起查询用户 id 为 1 的用户信息,先去找缓存中是否有 id 为 1 的用户信息,缓存中有,直接从缓存
    中获取用户信息。

Mybatis 二级缓存

  • 它指的是Mybatis中SqlSessionFactory对象的缓存。由同一个SqlSessionFactory对象创建的SqlSession共享其缓存。
  • 二级缓存的使用步骤:
    1. 第一步:让Mybatis框架支持二级缓存(在SqlMapConfig.xml中配置)
    2. 第二步:让当前的映射文件支持二级缓存(在IUserDao.xml中配置)
    3. 第三步:让当前的操作支持二级缓存(在select标签中配置)

二级缓存结构图

在这里插入图片描述

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

二级缓存的开启与关闭

第一步:在 SqlMapConfig.xml 文件开启二级缓存

<settings>
	<!-- 开启二级缓存的支持 -->
	<setting name="cacheEnabled" value="true"/>
</settings>

因为 cacheEnabled 的取值默认就为 true,所以这一步可以省略不配置。为 true 代表开启二级缓存;为false 代表不开启二级缓存。

第二步:配置相关的 Mapper 映射文件

<cache>标签表示当前这个 mapper 映射将使用二级缓存,区分的标准就看 mapper 的 namespace 值。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.dao.IUserDao">
<!-- 开启二级缓存的支持 -->
	<cache></cache>
</mapper>

第三步: 配置 statement 上面的 useCache 属性

<!-- 根据 id 查询 -->
<select id="findById" resultType="user" parameterType="int" useCache="true">
	select * from user where id = #{uid}
</select>

将 UserDao.xml 映射文件中的标签中设置 useCache=”true”代表当前这个 statement 要使用二级缓存,如果不使用二级缓存可以设置为 false。
注意: 针对每次查询都需要最新的数据 sql,要设置成 useCache=false,禁用二级缓存。

二级缓存注意事项

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

public class User implements Serializable {
        private Integer id;
        private String username;
        private Date birthday;
        private String sex;
        private String address;
    }
Xzzz2020 发布了77 篇原创文章 · 获赞 17 · 访问量 4843 私信 关注

标签:缓存,SqlSession,用户,二级缓存,Mybatis,查询
来源: https://blog.csdn.net/qq_43040688/article/details/104582215

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有