SpringBoot关闭MyBatis一级缓存的方法

原文网址:SpringBoot关闭MyBatis一级缓存的方法_IT利刃出鞘的博客-CSDN博客

简介

说明

        本文介绍SpringBoot关闭MyBatis一级缓存的方法。

备注

一级缓存只有在开启了数据库事物并且处于一个被事物标注的方法下【直接或间接】才会生效。

为什么要关闭MyBatis一级缓存

        默认情况下,MyBatis会开启一级缓存:对同样的查询将不再查询数据库,直接从缓存中获取。

        开启一级缓存存在的问题:如果不通过MyBatis修改数据,而是通过Navicat等工具,那么缓存中的数据不会被删除,导致MyBatis查到的还是以前的数据。

关闭MyBatis一级缓存的方法

        MyBatis没有提供一级缓存的启用、禁用开关,但在Mapper文件对应的语句中增加flushCache="true"可以达到实际禁用一级缓存的效果,一般同时还会加上useCache="false",以便关闭二级缓存。

下面讨论使用springboot配置的方式控制一级缓存。

MyBatis 一级缓存(MyBaits 称其为 Local Cache)无法关闭,但是有两种级别可选:

session

        在同一个 sqlSession 内,对同样的查询将不再查询数据库,直接从缓存中获取。

mybatis:
  configuration:
    cache-enabled: false  #禁用二级缓存
    local-cache-scope: session  #一级缓存指定为session级别

statement

        每次查询结束都会清掉一级缓存,实际效果就是禁用了一级缓存;

mybatis:
  configuration:
    cache-enabled: false #禁用二级缓存
    local-cache-scope: statement #一级缓存指定为statement级别

实测

@Transactional(propagation = Propagation.REQUIRED)
public List<Users> getUsers() {
    List<Users> usersList = usersMapper.selectByExample(new UsersExample());  //1
    usersList = usersMapper.selectByExample(new UsersExample());  //2
    return usersList;
}

A.一级缓存级别设置为session

        在代码中1处,通过日志观察,打印出sql语句,未走缓存【此时缓存数据还不存在】;

        在执行2处语句之前,通过数据库工具修改数据库记录并提交,继续执行程序后,通过日志观察,未打印出sql语句,获取的数据未体现出通过工具修改数据的变化,说明使用的是缓存中的数据;

B.一级缓存级别设置为statement

        在代码中1处,通过日志观察,打印出sql语句,未走缓存【此时缓存数据还不存在】;

        在执行2处语句之前,通过数据库工具修改数据库记录并提交,继续执行程序后,通过日志观察,打印出sql语句,且获取的数据也体现出通过工具修改数据的变化,说明未使用缓存中的数据;

结论:通过将一级缓存级别设置为statement,可以达到禁用一级缓存的效果。

在Spring Boot中使用MyBatis时,默认情况下是没有开启二级缓存的。要开启二级缓存,可以通过在全局配置文件(mybatis-config.xml)中进行配置,或者在application.yml文件中进行配置。 二级缓存是指在mapper-namespace级别的缓存,它可以提高查询性能,避免频繁地访问数据库。一级缓存是指在session级别的缓存,它默认是开启的,而且无法关闭。 要开启MyBatis的二级缓存,你可以在全局配置文件(mybatis-config.xml)中添加以下配置: ``` <configuration> <settings> <setting name="cacheEnabled" value="true" /> </settings> </configuration> ``` 或者在application.yml文件中添加以下配置: ``` mybatis: configuration: cache-enabled: true ``` 这样就可以开启MyBatis的二级缓存了。注意,开启二级缓存后,需要在Mapper接口的方法上使用@CacheNamespace注解来启用缓存。同时,还需要确保你的实体类实现了Serializable接口,以便支持缓存的序列化和反序列化操作。 总结起来,Spring Boot默认情况下是没有开启MyBatis二级缓存的,你需要进行相应的配置来启用二级缓存,并在Mapper接口的方法上使用@CacheNamespace注解来启用缓存。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [springboot-mybatis之二级缓存(注解方式)-随手记](https://blog.csdn.net/luning95/article/details/97756669)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [springboot+mybatis+redis 二级缓存问题实例详解](https://download.csdn.net/download/weixin_38618315/12767315)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT利刃出鞘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值