zoukankan      html  css  js  c++  java
  • Mybatis_查询缓存

    将上一次的查询结果保存在内存中,后面如果是相同的查询,就不再去数据库查询,到内存中获取数据。如果中间进行了增、删、改,需要清空缓存中的数据。

    好处:

    提高查询速度,减小数据库服务器压力

    Mybatis中的查询缓存:

    一级查询缓存

    如果使用的是同一个SqlSession对象中【没有被关闭过close()】,执行了多次相同的查询语句,第一次查询后会将结果保存到内存中,后面相同的查询会从内存中直接获取数据,而不再去数据中查询,提高查询速度。

    当一个SqlSession对象被关闭后,该SqlSession的上一次查询结果缓存中就不存在了。

    Mybatis中一级缓存默认就是开启状态,不需要手动启动,而且不能够进行关闭。

    一级缓存的验证:

    用同一个SqlSession对象执行相同的方法,控制台只有一次查询

    控制台

    如果使用的不同的SqlSession对象,那么不使用缓存

    如果使用的是同一个SqlSession对象,但是中间出现了增删改操作,缓存也不起作用

    结果

    二级查询缓存

    二级缓存与一级缓存,一级缓存当SqlSession关闭,则缓存数据不再存在,二级缓存的缓存数据与SqlSession对象无关。二级缓存延长缓存数据的保存时间。

    使用

    对查询语句中涉及到的实体类必须实现序列化接口

    在对应的映射文件中的mapper标签中添加cache子标签

    验证二级缓存的作用

    使用的是不同的SqlSession对象

    执行结果

     验证增删改对二级缓存的影响

    二级缓存在有增删改的时候会自动清空缓存,到数据库查找。

    学习中,博客都是自己学习用的笔记,持续更新改正。。。
  • 相关阅读:
    如何进入docker 使用root用户的方式
    阿里云服务搭建nginx并配置
    阿里云容器部署Redis集群
    Redis运维利器 -- RedisManager
    远程连接-使用SSH密钥对远程登录阿里云云服务器
    第1课:SQL注入原理深度解析
    数据库设计三大范式
    linux指令大全(归类整理)
    linux目录结构
    linux-创建/使用快照/克隆(类似windows中备份还原)
  • 原文地址:https://www.cnblogs.com/Tunan-Ki/p/11780115.html
Copyright © 2011-2022 走看看