mybatis的一级缓存和二级缓存
2023-12-26 18:31:20
MyBatis 是一个持久层框架,它提供了一级缓存和二级缓存来提高数据库访问性能。
一级缓存是 MyBatis 默认开启的缓存机制,它指的是在同一个 SqlSession 中进行的查询操作会将查询结果缓存在内存中,下次再执行相同的查询时,如果命中了缓存,就会直接从缓存中获取结果,而不需要再去数据库中查询。
二级缓存是在不同的 SqlSession 之间共享数据的缓存机制,它需要手动配置开启。当开启二级缓存后,同一个 namespace 下的 SQL 语句执行的结果将会被缓存起来,当其他 SqlSession 执行相同的 SQL 语句时,会先查看二级缓存中是否存在对应的数据,如果存在则直接返回缓存中的数据,而不需要再去执行 SQL 查询。
需要注意的是,一级缓存是 SqlSession 级别的缓存,生命周期比较短,而二级缓存是 Mapper 级别的缓存,生命周期较长。在使用二级缓存时,需要考虑缓存的更新策略,避免脏数据的产生。
总的来说,一级缓存是 SqlSession 级别的缓存,适合用于在同一个请求中频繁地查询相同的数据;而二级缓存是全局级别的缓存,适合用于跨请求共享数据,但需要注意缓存的更新机制。
文章来源:https://blog.csdn.net/wang121213145/article/details/135225519
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!