MyBatis 内置了一个强大的事务性查询缓存机制,它可以非常方便地配置和定制。 为了使它更加强大而且易于配置,官方对 MyBatis 3 中的缓存实现进行了许多改进。
默认情况下,只启用了本地的会话缓存【一级缓存】,它仅仅对一个会话中的数据进行缓存。
一级缓存是SqlSession级别的缓存,每个SqlSession都有自己单独的一级缓存,多个SqlSession之间的一级缓存是相互隔离的,互不影响,MyBatis 中一级缓存是默认自动开启的。
一级缓存工作原理:
在同一个SqlSession中去多次去执行同样的查询,每次执行的时候会先到一级缓存中查找,如果缓存中有就直接返回,如果一级缓存中没有相关数据,mybatis就会去db中进行查找,然后将查找到的数据放入一级缓存中,第二次执行同样的查询的时候,会发现缓存中已经存在了,会直接返回。一级缓存的存储介质是内存,是用一个HashMap来存储数据的,所以访问速度是非常快的。
- 一级缓存案例:【部分代码】
UserMapper.xml
<select id=