Mybatis一级、二级缓存

MyBatis一级、二级缓存总结
1、 mybatis的一级缓存SqlSession缓存
sqlSession缓存是默认开启的,在一个sqlSession在使用select的时候会先从本地缓存中读,如果没有才会连接数据库查询相关的数据,然后将查询的数据放入本地缓存,以便下次select。只要没有事务提交( 增删该等动作)和没有 Session flush 或 close操作,就不会清空session缓存, 执行查询条件相同的第二次查询,就直接从缓存中取,不发sql。

2、 mybatis的二级缓存Mapper级别的缓存
mybatis的二级缓存是namespace级别的,就是使用同一Mapper Namespace下的select标签的sqlSession 共享一个缓存。因此只要有一个sqlSession发出了一个查询,第二sqlSession发出同样的查询的话,是直接从二级缓存中取数据的。
二级缓存默认不开启,如果要使用的话要在mybatis-config.xml的全局配置文件中开启,同时要在mapper 的sql映射文件中配置cache, 此外缓存的对象 必须 implments Serializable接口。
(以上参考:http://m.blog.csdn.net/u014297148/article/details/78696073

其他
  正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持。
  
一级缓存: 基于PerpetualCache 的 HashMap本地缓存,其存储作用域为 Session,当 Session commit 或 flush 或 close 之后,该Session中的所有 Cache 就将清空。一级缓存使用的是本地内存。

二级缓存:与一级缓存其机制相同,默认也是采用 PerpetualCache,HashMap存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如 Ehcache。也可以使用第三方内存缓存库,如Memcached、OSCache等。
(以上参考:http://www.cnblogs.com/xdp-gacl/p/4270403.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值