Mybatis 的二级缓存机制
什么是缓存
- 缓存其实就是存储在内存中的临时数据,这里的数据量会比较小,一般来说,服务器的内存也是有限的,不可能将所有的数据都放到服务器的内存里面,所以, 只会把关键数据放到缓存中,缓存因为速度快,使用方便而出名!Mybatis作为一款优秀的ORM框架,自然也提供了缓存机制。
二级缓存机制
介绍
- Mybatis设计了二级缓存来提高查询效率,避免每次都去直接查询数据库。
- 一级缓存,它是 SqlSession 级别的缓存,也叫本地缓存,因为每个用户在执行查询的时候都需要使用 SqlSession 来执行,为了避免每次都去查数据库,MyBatis 把查询出来的数据保存到 SqlSession 的本地缓存中,后续的 SQL 如果命中缓存,就可以直接从本地缓存读取。
- 想要实现跨 SqlSession 级别的缓存,一级缓存就无法实现了,因此,MyBatis引入了二级缓存。当多个用户在查询数据的时候,只要有任何一个 SqlSession 拿到了数据就会放入到二级缓存里面,其他的 SqlSession 就可以从二级缓存加载数据。
- Mybatis读取缓存的顺序:先读取二级缓存再读取一级缓存。
原理
一级缓存的实现原理:
- 在 SqlSession 里面持有一个 Executor 的对象,每个 Executor 中有一个 LocalCache 对象。当用户发起查询的时候,MyBatis 会根据执行语句在 Local Cache 里面查询,如果没命中,再去查询数据库并写入到 LocalCache,否则直接返回。 一级缓存的生命周期为sqlSession。
二级缓存的实现原理:
- 二级缓存使用了一个叫做 CachingExecutor 的对象,对 Executor 进行了装饰,在进入一级缓存的查询流程之前,会先通过 CachingExecutor 进行二级缓存的查询。开启二级缓存以后,会被多个 SqlSession 共享,所以它是一个全局缓存。因此它的查询流程是先查二级缓存,再查一级缓存,最后再查数据库。
- 二级缓存相对于一级缓存来说,它实现了sqlsession之间的缓存数据的共享,同时缓存粒度也能控制到namespace的一个级别,并且还可以通过Cache的接口来实现不同缓存实现类的组合,对Cache的可控性也更高了。