2020-08-26

一、Mybatis 1,2级缓存处理
知识点:
1级缓存使用场景
2级缓存使用场景

1级缓存使用场景
订单表与会员表是存在一对多的关系 为了尽可能减少join 查询,进行了分阶段查询,即先查询出订单表,在根据member_id 字段查询出会员表,最后进行数据整合 。如果订单表中存在重复的member_id,就会出现很多没必要的重复查询。
针对这种情况myBatis 通过1缓存来实现,在同一次查询会话中如果出现相同的语句及参数,就会从缓存中取出不在走数据库查询。1级缓存只能作用于查询会话中 所以也叫做会话缓存。

一级缓存的使用条件:
1.必须是相同的SQL和参数
2.必须是相同的会话
3.必须是相同的namespace 即同一个mapper
4.必须是相同的statement 即同一个mapper 接口中的同一个方法
5.查询语句中间没有执行session.clearCache() 方法
6.查询语句中间没有执行 insert update delete 方法(无论变动记录是否与 缓存数据有无关系)

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容