Mybatis中的一级缓存和二级缓存
一级缓存:
它指的是Mybatis中SqlSession对象的缓存。
当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。
该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中
查询是否有,有的话直接拿出来用。
当SqlSession对象消失时,mybatis的一级缓存也就消失了。
创建新项目

复制pom.xml的依赖

导入一对多的代码


只需要演示缓存,很多代码不需要。 删除IAccountDao

Account和AccountUser删除


测试类中的删除AccountTest删除

因为没有account。所以这里resultMap可以删除掉。

返回的这里改成resultType="user" 而不用resultMap



查询两次id为41的 判断 两个结果集的引用地址是否为一个

把实体类重写的toString方法先注释掉。

测试方法。运行结果。地址为同一个

只发起了一次查询

演示session关闭缓存消失


再次执行测试方法
对象的引用只不再是同一个

获取了两次SqlSession对象。执行两次select查询

当SqlSession消失时我们的一次缓存也消失了
clearCache

虽然是一个SqlSession但是 是两次查询
