一级缓存的介绍
一级缓存的范围是sqlsession级别,同一个sqlsession执行同一个sql查询(相同的sql和参数),第一次会去查询数据库并写到缓存中,第二次从一级缓存中取。
一级缓存是基于PerpetualCache的HashMap本地缓存,默认开启一级缓存。
什么时候清除一级缓存如果中间的sqlSession去执行提交操作(执行插入、更新、删除),会清除SqlSession中的一级缓存,这样做的目的是让缓存存储最新的信息,避免脏读。
如果执行commit、close、add、delete、update等操作,当前的一级缓存就会被清空;当对SqlSession执行更新操作(更新、删除、插入)后再执行commit,不仅自身的一级缓存会被清空(执行更新操作的效果),而且二级缓存也会被清空(执行commit()的效果)。
一级缓存没有过期时间,只有一个生命周期当MyBatis打开一个数据库会话时,它会创建一个新的SqlSession对象,它有一个Executor对象,Executor对象持有一个PerpetualCache对象,见下面的代码。当会话结束时,SqlSession对象及其内部的Executor对象和PerpetualCache对象也被一起释放。