mybatis清除一级缓存的几种方式
更新时间:2024年03月09日 09:38:59 作者:Smaksze
这篇文章主要介绍了mybatis清除一级缓存的几种方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
mybatis清除一级缓存方式
1、手动清空
sqlSession.clearCache()
2、Options注解
public interface UserMapper{
@Options(flushCache= Options.FlushCachePolicy.TRUE)
User selectById(@params("id")Integer id)
}3、调用了修改的方法时,底层直接调用sqlSession.clearCache()一次性全部清空
4、在setting中关闭一级缓存
locaCacheScope = STATEMENT
5、手动提交/回滚
mybatis一级缓存何时失效
mybatis的一级缓存是 SqlSession 级别的缓存,它存在于 SqlSession 的生命周期内,当 SqlSession 关闭时,一级缓存也会随之失效。
具体来说,一级缓存可能失效的情况包括:
- SqlSession 执行 clearCache() 方法,显式地清空缓存。
- SqlSession 执行 close() 方法,关闭 SqlSession 时,所有的一级缓存数据都会被销毁。
- SqlSession 开始一个事务后,如果事务被提交或者回滚则会清空当前 SqlSession 对应的所有的一级缓存。
- SqlSession 在执行 insert, update, delete 等更新操作时,会清空当前 SqlSession 对应的所有的一级缓存。因为这些操作可能会对查询结果产生影响,缓存数据无效。
总之:
我们在使用 MyBatis 的时候,需要充分了解一级缓存的实现原理和失效情况,避免因为缓存问题导致程序运行出现错误。
如果遇到缓存失效的问题,可以通过修改配置文件或者手动清空缓存等措施来解决。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java SimpleDateFormat中英文时间格式化转换详解
这篇文章主要为大家详细介绍了Java SimpleDateFormat中英文时间格式化转换,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-12-12
EasyExcel实现读取excel中的日期单元格并自动判定终止读取
这篇文章主要为大家详细介绍了EasyExcel如何实现读取excel中的日期单元格并自动判定终止读取,感兴趣的小伙伴可以跟随小编一起学习一下2024-11-11


最新评论