一、mybatis四个核心对象的生命周期
- SqlSessionFactoryBuilder:只用一次 存在于方法体中,用于解析配置文件,构建SqlSessionFactory
- SqlSessionFactory:全局单例 存在整个生命周期,用于创建SqlSession
- SqlSession:线程不安全的,存在于每次操作数据库创建这个对象, 用于创建Mapper
- Mapper:都是代理对象,存在于sqlsession操作数据库期间
二、 一级缓存(同一个SqlSession)
一级缓存在SqlSession子类 → DefaultSqlSession的属性 → Executor子类 → BaseExecutor的属性 → PerpetualCache(缓存唯一实现类,其他的实现类都是装饰者)的map中
-
mybatis-config.xml 关闭二级缓存,
-
mapper.xml
-
测试:
测试结果:
-
影响一级缓存的操作,ex:
-
mapper标签
-
不同的会话
-
更新操作(再次查询有脏数据)
三、 二级缓存(同一个namespace中)
DefaultSqlSession的属性 → Executor子类 → CachingExecutor(装饰者装饰一级缓存)属性 → TransactionalCacheManager
- 开启二级缓存
mybatis-config.xml
mapper.xml中
![![在这里插入图片描述](https://img-blog.csdnimg.cn/2019100513293585.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQxMzAxMDc5,size_16,color_FFFFFF,t_70) - 测试:
测试结果:
- 关闭二级缓存:
- 更新操作二级缓存会被刷新,所以不会有脏数据
- 一个namespace操作另一个namespace,二级缓存会失效
四、缓存的查找顺序
先从二级缓存,再一级缓存,最后数据库