Mybatis的一二级缓存

总述: Mybatis提供一级缓存和二级缓存的机制。一级缓存是SqlSession级别的缓存。在操作数据库时,每个SqlSession类的实例对于对象有一个数据结构(HashMap)可以用于存储缓存数据。不同的SqlSession类的实例对象缓存数据区域(HashMap)是互不影响的。二级缓存是Mapper级别的缓存,多个SqlSession类实例对象操作同一个Mapper配置文件中的SQL语句,多个SqlSession类实例的对象可以共用二级缓存,二级缓存是跨SqlSession.
一二级缓存示意图

一级缓存:
当第一次查询用户信息时,sqlSession首先到一级缓存区域中查询某一id,如果没有相关数据则从数据库查询。然后sqlSession将该查询的结果保到一级缓存区域。在下一次查询的时,如果sqlSession执行了commit操作(即执行了修改、添加和删除),则会清空他的一级缓存区域,以此来保证缓存中的信息是最新的,避免可脏读现象的发生。如果在这期间sqlSession一直没有执行commit操作修改数据,那么下一次执行相同id信息时,sqlSession在一级缓存中就会发现该信息,然后从缓存中获取信息。

二级缓存:
在二级缓存中,多个sqlSession类的实例对象可以共享一个Mapper的二级缓存区域。一个Mapper有一个自己的二级缓存区域(按照namespace划分),两个Mapper的namespace如果相同,那么这两个Mapper执行的SQL查询会被缓存在同一个二级缓存中。

猜你喜欢

转载自blog.csdn.net/ocean_java666/article/details/81145949