上一节我们学习Mybatis的缓存使用了元素,在mapper文件中进行设置,这种配置属于Mybatis的二级缓存。Mybatis本身具有一种缓存机制,是针对与SQLsession级别的缓存,称之为一级缓存。本节小博老师给大家介绍下一级缓存和二级缓存的区别。
所谓一级缓存是指,MyBatis执行SQL语句之后,该语句及结果会被缓存,以后再执行这条语句的时候,会直接从缓存中拿结果,而不是再次执行SQL。一级缓存的作用域是SqlSession。
这段代码只会执行一次sql语句查询。第二次读取user对象时,不再执行sql语句查询,直接从缓存中读取。
但是如果是从不同的session中获取相同的user对象呢?代码做如下修改:
我们发现,控制台打印了两次sql语句查询:
上节课我们配置的元素是二级缓存,二级缓存的作用域是全局,换句话说,二级缓存不受SqlSession控制,但需要记住一点:二级缓存在SqlSession关闭或提交之后才会生效。
在mapper中加入元素,然后对上面的代码略作修改:
在第一个session查询完成后,需要commit或者close,否则仍然会执行两次sql查询。观察控制台,我们发现Mybatis只执行了一次sql查询: