mybatis一级缓存和二级缓存有什么区别
MyBatis的一级缓存和二级缓存是两种不同级别的缓存机制。
一级缓存是在同一个SqlSession内部的缓存,它默认是开启的。在执行查询操作时,查询的结果会被缓存到一级缓存中,下次执行相同的查询操作时,会直接从缓存中获取结果,而不需要再次查询数据库。一级缓存的生命周期是和SqlSession绑定的,当SqlSession提交或关闭时,一级缓存就会失效。
二级缓存是在同一个Mapper命名空间下的缓存,它是跨SqlSession的缓存机制。一级缓存只能在同一个SqlSession中生效,而二级缓存可以在多个SqlSession中共享缓存数据。当开启了二级缓存后,在执行查询操作时,查询的结果会被缓存到二级缓存中,下次执行相同的查询操作时,会先从二级缓存中获取结果,如果缓存中不存在,则会再查询数据库,并将查询结果放入缓存中。二级缓存的生命周期是和Mapper命名空间绑定的,在同一个Mapper命名空间下的SqlSession执行了update、insert、delete等操作时,会清空对应的二级缓存。
总结来说,一级缓存是在SqlSession级别的缓存,生命周期短暂,只对同一个SqlSession有效;二级缓存是在Mapper命名空间级别的缓存,生命周期相对长久,可以在多个SqlSession中共享缓存数据。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341