首页IT科技mybatisplus缓存导致查询不到新数据(学习笔记——Mybatis中缓存机制)

mybatisplus缓存导致查询不到新数据(学习笔记——Mybatis中缓存机制)

时间2025-09-19 11:12:00分类IT科技浏览4964
导读:2023-01-12...

2023-01-12

一                、Mybatis中缓存机制

1                       、一级缓存

(1)概述:一级缓存(即本地缓存或SqlSession级别缓存)

(2)特点:

①一级缓存默认开启

②不能关闭

③可以清空

(3)缓存原理

①当第一次获取数据时               ,需要先从数据库中加载数据                      ,将数据缓冲到Mybatis一级缓存中(缓存底层实现原理是Map,key:hashCode+查询的SqlId+编写的sql查询语句+参数)

②以后再次获取数据时        ,先从一级缓存中获取            ,如未获取到数据                      ,再从数据库中获取数据

(4)一级缓存五种失效情况

①不同的SqlSession对应不同的一级缓存(例如:将第一次查询的sqlSession关闭了            ,之后开启一个新的sqlSession)

②同一个sqlSession但是查询条件不同

③同一个sqlSession两次查询期间执行了任何一次增删改查操作

④同一个sqlSession两次查询期间手动清空了缓存

⑤同一个sqlSession两次查询期间提交了事务

2      、二级缓存

(1)二级缓存概述

(1)二级缓存(即全局作用域缓存)

(2)SqlSessionFactory级别缓存

(2)二级缓存的特点

①二级缓存默认关闭        ,需要开启时才能使用

②二级缓存需要提交sqlSession或关闭sqlSession时                      ,才会缓存

(3)二级缓存使用的步骤

①全局配置文件中开启二级缓存

②需要使用二级缓存的映射文件使用cache配置缓存

③注意:POJO需要实现Serializable接口

在POJO中的类中添加“implements Serializable                ”

之后点击小扳手图标                ,将如下的设置进行勾选                。

之后将光标放置在POJO类的后面    ,同时按“Alt+Enter                       ”,在类中会添加“serialVersionUID      ”的设置

④关闭sqlSession或提交sqlSession时                      ,将数据缓存到二级缓存

(4)二级缓存中的原理

①当第一次获取数据时                    ,需要先从数据库中获取数据,将数据缓冲到Mybatis一级缓存中;当提交或关闭SqlSession时                  ,将数据缓存至二级缓存                       。

②以后再次获取数据时                       ,先从一级缓存中获取数据    ,如一级数据没有指定数据               ,再去二级缓存中获取数据      。如二级缓存也没有指定数据时                      ,需要去数据库中获取数据            。

(5)二级缓存的属性

①eviction="FIFO":缓存清除“回收            ”策略

LRU——最近最少使用的:移除最长时间不被使用的对象

FIFO——先进先出:按对象进入缓存的顺序来移除它们                        。

②flushInterval:刷新间隔        ,单位毫秒

③size:引用数目            ,正整数

④readOnly:只读                      ,true/false

(6)二级缓存的失效情况

在两次查询之间            ,执行增删改操作        ,会同时清空一级缓存和二级缓存

SqlSession.clearCache():只是用来清除一级缓存          。

3            、第三方缓存

EhCache:是一个纯java的进程内缓存框架                      ,具有快速                        、精干等特点                ,是Hibernate中默认的CacheProvider

(1)使用步骤

①导入jar包

在pom.xml中的<dependencies>中添加jar包

<!-- https://mvnrepository.com/artifact/org.mybatis.caches/mybatis-ehcache --> <dependency> <groupId>org.mybatis.caches</groupId> <artifactId>mybatis-ehcache</artifactId> <version>1.0.3</version> </dependency> <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12 --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.6.2</version> <scope>test</scope> </dependency>

②编写核心配置文件

<?xml version="1.0" encoding="UTF-8" ?> <ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd"> <!--diskStore: 持久化到磁盘上时的存储位置--> <diskStore path="E:\mybatis\ehcache"/> <defaultCache maxElementsInMemory="512" maxElementsOnDisk="10000000" eternal="false" overflowToDisk="true" timeToIdleSeconds="120" timeToLiveSeconds="120" diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU"> </defaultCache> </ehcache>

③加载第三方缓存(映射文件)

<cache type="org.mybatis.caches.ehcache.EhcacheCache"></cache>

④开始使用

注意:

第三方缓存    ,需要建立在二级缓存基础上(即需要开启二级缓存)

声明:本站所有文章                      ,如无特殊说明或标注                    ,均为本站原创发布        。任何个人或组织,在未征得本站同意时                  ,禁止复制          、盗用        、采集                        、发布本站内容到任何网站              、书籍等各类媒体平台                        。如若本站内容侵犯了原著者的合法权益                       ,可联系我们进行处理              。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
如何实现sql语句的优化操作(如何实现SQL语句的优化?)