MyBatis中二级缓存和一级缓存有什么区别

   2024-10-27 3840
核心提示:MyBatis中的一级缓存是SqlSession级别的缓存,即在同一个SqlSession中执行相同的查询,第一次查询结果会被缓存下来,后续再执行

MyBatis中的一级缓存是SqlSession级别的缓存,即在同一个SqlSession中执行相同的查询,第一次查询结果会被缓存下来,后续再执行相同的查询时,直接从缓存中获取结果,提高查询效率。但是一级缓存的生命周期比较短,当SqlSession关闭时,缓存也会失效。

而二级缓存是Mapper级别的缓存,即多个SqlSession共享同一个Mapper的缓存。当执行查询时,MyBatis会先在二级缓存中查找结果,如果找到则直接返回结果,如果没有则再去数据库查询并将结果存入二级缓存中。二级缓存的生命周期比较长,可以跨SqlSession共享数据,但是需要开启和配置才能生效。

 
举报打赏
 
更多>同类网点查询
推荐图文
推荐网点查询
点击排行

网站首页  |  关于我们  |  联系方式网站留言    |  赣ICP备2021007278号