Mybatis 缓存

  为什么使用缓存?

 对于一些我们经常查询的并且不经常改变的数据,如果每次查询都要与数据库进行交互,那么大大降低了效率,因为我们使用缓存,将一些对结果影响不大且经常查询的数据存放在内存中,从而减少与数据库的交互来提高效率,这就是缓存的优势。

mybatis中的一级缓存 

   一级缓存指的是 mybatis中SQLSession对象的缓存

当我们在执行查询操作时,查询的结果同时会存入SqlSession提供的一块区域。该区域是一个Map结构,当我们再次查询同样的数据时,mybatis会先去SQLSession中找,有的话直接拿来用,SQLSession消失后,一级缓存也就消失了

如何清空缓存?

使用SqlSession对象调用clearCache()方法    SqlSession.clearCache();

注意 :

看到这可能会有个疑问,如何两次查询一个数据时,中间对这个数据进行了修改,那么第二次查询的结果会不会修改呢?答案是会的。因为在mybatis中,除了使用clearCache()方法时会清空缓存,对数据进行 增,删,改,commit(),close()时也会对一级缓存进行清空。

mybatis中的二级缓存 

  二级缓存指的是 mybatis中SqlSessionFactory对象的缓存 ,由同一个SqlSessionFactory对象 创建的SqlSession共享缓存。

   配置步骤:

   一、在配置文件 config.xml中配置,让mybatis支持二级缓存   settings 标签中 使用cacheEnabled value 设置为true

 

二、在映射配置文件中 开启支持二级缓存                   加上<cache/>标签

三、让当前操作支持二级缓存,即在select标签 加上  useCache="true"

 

(如果使用注解方式,在Dao的类名上添加@CacheNamespace (blocking=true)注解)

注意

mybatis的二级缓存SqlSessionFactory中存放的是是数据 而不是对象

  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值