MyBatis 一级缓存

一级缓存

  它指的是mybatis中sqlsession对象的缓存。

  当我们执行查询后,查询的结果会同时存到sqlsession为我们提供的一块区域,该区域的结构是个map。

  当我们再次查询同样的数据,这样mybatis会去sqlsession中查看是否有,有的话会直接拿出来用。

  当sqlsession消失时,mybatis的一级缓存也就消失了。

  我们用一个测试类看看效果

  运行一下我们发现只发起了一次sql查询,也就是说第二次是从缓存查询的数据

  如果说第一次查询后我们关闭了sqlsession对象,那么就意味着缓存区域被关闭了

  这个时候两个user对象就不是同一个了,返回的是false

  且发起的查询是两次

   除了关闭sqlsession,sqlsession还提供了clearCache方法清空缓存 

分析

  如果涉及数据的更新,mybatis是如何保持数据的一致呢?

  我们在两次查询中加入更新的操作

   运行一下我们可以看到,第二次查询没有在缓存里取,而是向数据库发起了新的查询

  这是为什么呢?

  那是因为MyBatis调用sqlsession的修改,添加,删除,commit,close方法会清空一级缓存。

  所以上面我们调用了updata方法,sqlsession的一级缓存就被清除了。

原文地址:https://www.cnblogs.com/qq2210446939/p/13624479.html