Mysbatis一级缓存
一级缓存是SqlSession级别的缓存,缓存对数据库的操作的结果,如果下一次用户再执行相同的请求,那么直接从内存中读取而不是从数据库读取。
一级缓存失效的情况:
1.只对当前SqlSession对象生效,对于其他的SqlSession来说不起作用
2.是当前SqlSession对象,但是执行的是不同条件的SQL查询语句。
3.同一个SqlSession对象执行同一条件的查询语句,但中间执行了增删改的操作,之前一级缓存中的数据会失效。如果执行的是不同条件的查询语句,一级缓存仍然生效,并且会把新的查询数据也加入到一级缓存中。
4.多次相同查询语句在执行期间通过sqlSession.clearCache();方法清除了缓存
5.SqlSession 对象调用了close()方法,当前会话结束,一级缓存不再生效。
Mysbatis二级缓存
二级缓存就是全局缓存它超出session范围之外,可以被所有Session共享,需要注意的是全局缓存的作用域是针对Mapper的Namespace而言的,也就是说只在有在这个Namespace内的查询才能共享这个cache,但并不是意味着同一个namespace创建的mapper可以互相读取缓存内容,
保存顺序:每个SqlSession在执行查询操作的时候,都会将查询的结果放在当前会话的一级缓存中。如果当前会话关闭,一级缓存中的数据会被保存在二级缓存中。因此二级缓存是在一级缓存的基础上进行扩展的,不同的namespace查出的数据都会将数据存在自己对应的缓存中,这些缓存信息使用Map存储。
查询顺序:MyBatis 在开启二级缓存的情况下,如果发出了一条SQL 查询语句,会先向二级缓存中查询是否有对应的缓存数据,如果没有再接着查询一级缓存中的数据,如果一级缓存中也没有对应的缓存数据,才会向数据库发送SQL。