mybatis的一级缓存与二级缓存

mybatis的一级缓存与二级缓存;同一个sqlSession共享结果集

mybatis的一级缓存是针对sqlSession的,同一个方法内,多个数据库的操作,会创建多个sqlSeesion;添加事务处理后在同一个方法内会创建一个sqlSession,多线程情况下还是会创建多个sqlSession,对于两次同样的查询,会缓存第一次的查询结果,数据缓存一map格式进行保存,以sqlSession的hashcode+statementId+sql语句为key,查询出的对象为value;进行增删改的commit操作后,会清空缓存;一级缓存是默认开启的,可以通过设置flushCashe=“true”,但是每次查询还是会保存进去。

 

二级缓存是mapper级别的,不同的sqlSession之间可以共享结果集

默认是不开启的,第一次调用mapper下的sql去查询时,会把查询结果缓存在该mapper对应的二级缓存区域,第二次调用该namespace下的mapper映射文件时,相同的sql信息会在缓存中去去结果。因为同一个namespace可能会操作几个表,数据更新后namespace下的二级缓存没有更新,产生脏数据。在mapper的每个sql中可以通过配置useCache来开启和关闭二级缓存,也可以通过在SqlMapConfig.xml文件中通过添加二级缓存的总开关:cacheEnabled=true来开启

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值