一、理解缓存
我们先来理解一下,什么是Mybatis中的缓存
-
什么是缓存?
存在于内存中的临时数据。
-
为什么使用缓存?
减少和数据库的交互次数,提高执行效率。
-
什么样的数据能使用缓存,什么样的数据不能使用?
适用于缓存: 经常查询并且不经常改变的。 数据的正确与否对最终结果影响不大的。 不适用于缓存: 经常改变的数据 数据的正确与否对最终结果影响很大的。 例如:商品的库存,银行的汇率,股市的牌价。
-
Mybatis中的一级缓存:
它指的是Mybatis中SqlSession对象的缓存。 当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。 该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中 查询是否有,有的话直接拿出来用。 当SqlSession对象消失时,mybatis的一级缓存也就消失了。
二、演示一级缓存
#### 演示一级缓存:回到我们的环境,我们把User实体类里面的toString方法给注释掉
#### 接着findById方法
#### 回到我们的测试类,运行,我们发现,我们调用了两次findById方法,但结果只进行了一次查询,并且我们的两个user对象是相同的,这是因为我们的mybatis用了一级缓存,查询相同的没有再进行查询。
三、关闭一级缓存
第一种方法:
#### 那我们如何关闭一级缓存,让它不适用缓存呢?我们知道一级缓存是SqlSession对象的缓存,那我们把Sqlsession给关了,再获取就好了,回到我们的测试类,做修改,修改如下:
#### 回到我们的测试类,运行,我们发现一级缓存没有了,两次调用,执行了两次查询,并且两个user对象不相同。
第二种方法:
#### 上面的关了sqlsession再获取是一种方法,但还有另外一种方法,sqlSession.clearCache(),如下。
四、一级缓存补充
我们来看一个例子
创建一个修改用户信息的接口
接着配置sql语句,修改用户信息
回到测试类,运行测试方法
我们发现,我们并没有关闭一级缓存,那为什么会执行两次查询语句呢???
这里我们需要补充一下:
一级缓存是SqlSession范围的缓存,当调用SqlSession的修改,添加,删除,commit(),close()等方法时,就会清空一级缓存。
上面我们调用了update修改方法,所以就清空了一级缓存。