java项目性能优化(MyBatis中开启查询缓存及flushCache与useCache的使用)

在java项目中,如果需要大量的DB查询,导致缓存过多,项目运行缓慢,可以设置在select查询时,添加二级缓存的清空。

如果没有去配置flushCache、useCache,那么默认是启用缓存的。

1,flushCache默认为false,表示任何时候语句被调用,都不会去清空本地缓存和二级缓存。

2,useCache默认为true,表示会将本条语句的结果进行二级缓存。

在insert、update、delete语句时: flushCache默认为true,表示任何时候语句被调用,都会导致本地缓存和二级缓存被清空。 useCache属性在该情况下没有。update 的时候如果 flushCache="false",则当你更新后,查询的数据数据还是老的数据。

在Mapper的具体方法下设置对二级缓存的访问意愿:

复制代码
<select id="save" parameterType="XX" flushCache="true" useCache="false"> </select>

同时设置 flushCache="true" useCache="false"

那么就是,第一次查询后,清空二级缓存,并且以后都不会在缓存中保存数据。

参考资料:

[mybatis]缓存_缓存有关的设置以及属性

MyBatis中开启查询缓存及flushCache与useCache的使用

mybatis复习与总结(八)------缓存

相关推荐
爱滑雪的码农2 分钟前
Java基础五:运算符与循环结构
java·开发语言
MrSYJ3 分钟前
Netty异常传播机制
java·服务器·netty
WangJunXiang68 分钟前
Nginx性能优化与监控笔记
笔记·nginx·性能优化
于先生吖11 分钟前
基于 Java 开发智慧社区系统:跑腿 + 家政 + 本地生活服务实战教程
java·开发语言·生活
魑魅魍魉都是鬼11 分钟前
JAVA面向对象设计的五大原则
java
小箌13 分钟前
springboot_01
java·spring boot·后端
sunwenjian88618 分钟前
Spring Cloud gateway 路由规则
java
panzer_maus18 分钟前
死锁的产生与解决
java·开发语言
asom2221 分钟前
MVC vs DDD
java·mvc·ddd
凯子坚持 c24 分钟前
基于C++构建DeepSeek大模型推理SDK:从架构设计到工程落地
java·数据库·c++