博为峰JavaEE技术文章 ——MyBatis 缓存(2)一级缓存与二级缓存
2017-02-14 00:00
429 查看
上一节我们学习Mybatis的缓存使用了<cache>元素,在mapper文件中进行设置,这种配置属于Mybatis的二级缓存。Mybatis本身具有一种缓存机制,是针对与SQLsession级别的缓存,称之为一级缓存。本节小博老师给大家介绍下一级缓存和二级缓存的区别。
所谓一级缓存是指,MyBatis执行SQL语句之后,该语句及结果会被缓存,以后再执行这条语句的时候,会直接从缓存中拿结果,而不是再次执行SQL。一级缓存的作用域是SqlSession。
这段代码只会执行一次sql语句查询。第二次读取user对象时,不再执行sql语句查询,直接从缓存中读取。
但是如果是从不同的session中获取相同的user对象呢?代码做如下修改:
我们发现,控制台打印了两次sql语句查询:
上节课我们配置的<cache>元素是二级缓存,二级缓存的作用域是全局,换句话说,二级缓存不受SqlSession控制,但需要记住一点:二级缓存在SqlSession关闭或提交之后才会生效。
在mapper中加入<cache/>元素,然后对上面的代码略作修改:
在第一个session查询完成后,需要commit或者close,否则仍然会执行两次sql查询。观察控制台,我们发现Mybatis只执行了一次sql查询:
所谓一级缓存是指,MyBatis执行SQL语句之后,该语句及结果会被缓存,以后再执行这条语句的时候,会直接从缓存中拿结果,而不是再次执行SQL。一级缓存的作用域是SqlSession。
这段代码只会执行一次sql语句查询。第二次读取user对象时,不再执行sql语句查询,直接从缓存中读取。
但是如果是从不同的session中获取相同的user对象呢?代码做如下修改:
我们发现,控制台打印了两次sql语句查询:
上节课我们配置的<cache>元素是二级缓存,二级缓存的作用域是全局,换句话说,二级缓存不受SqlSession控制,但需要记住一点:二级缓存在SqlSession关闭或提交之后才会生效。
在mapper中加入<cache/>元素,然后对上面的代码略作修改:
在第一个session查询完成后,需要commit或者close,否则仍然会执行两次sql查询。观察控制台,我们发现Mybatis只执行了一次sql查询:
相关文章推荐
- 博为峰JavaEE技术文章 ——MyBatis 缓存(2)一级缓存与二级缓存
- 博为峰JavaEE技术文章 ——MyBatis 缓存(1)
- 博为峰JavaEE技术文章 ——MyBatis 缓存(1)
- 博为峰JavaEE技术文章 ——MyBatis 缓存(3)自定义缓存
- 博为峰JavaEE技术文章 ——MyBatis 缓存(3)自定义缓存
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(4)
- 博为峰JavaEE技术文章 ——MyBatis 简单应用
- 博为峰JavaEE技术文章 ——MyBatis 简介(2)
- 博为峰JavaEE技术文章 ——MyBatis Mapper Select
- 博为峰JavaEE技术文章 ——MyBatis Mapper TypeHandler
- 博为峰JavaEE技术文章 ——MyBatis 简介(2)
- 博为峰JavaEE技术文章 ——MyBatis 接口编程
- 博为峰JavaEE技术文章 ——MyBatis Mapper Insert Update Delete
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(2)
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(3)
- 博为峰JavaEE技术文章 ——MyBatis Mapper $与#的区别
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(3)
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(5)constructor
- 博为峰JavaEE技术文章 ——MyBatis Mapper ResultMap(4)