一级缓存默认开启, 有效范围是在当前sqlsession,
同一个SqlSession对象执行相同的sql并参数也要相同,缓存才有效。
在同一个会话里面,多次执行相同的SQL 语句,会直接从内存取到缓存的结果
一级缓存不足: 使用一级缓存的时候,因为缓存不能跨会话共享,不同的会话之间对于相同的数据可能有不一样的缓存。在有多个会话或者分布式环境下,会存在脏数据的问题。
二级缓存的有效方范围是 Mapper(NameSpace), 多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。二级缓存的作用范围更大。
注入的单例 SqlSessionTemplate 内部包含SqlSessionProxy对象, 对每次SqlsessionTemplate的调用被代理为新创建的sqlsession的调用,所以sqlsessiontemplate每次调用都会有一个新的session生成.
SqlSession 持有了一个Executor 对象,用来封装对数据库的操作。
SqlSession 持有了一个Configuration对象,用来保存所有配置信息。
二级缓存范围更广工作在SqlSession外部(实际上是使用装饰器)
Mybatis基本框架
一级缓存机制
DefaultSqlSession 里面只有两个属性,Configuration 是全局的,所以缓存只可能放在Executor 里面维护——SimpleExecutor/ReuseExecutor/BatchExecutor 的父类
BaseExecutor 的构造函数中持有了PerpetualCache。
原文地址:https://www.cnblogs.com/snow-man/p/10812294.html
时间: 2024-10-16 13:53:20