ibatis 一级缓存和二级缓存 遇到的问题,更新后查询问题

在使用Ibatis和Spring MVC时,遇到更新数据后查询结果仍显示旧值的问题。初步排除了Spring事务传播错误,通过日志分析发现并非SQLSession问题,而是Ibatis的一级缓存所致。即使在XML配置中禁用了二级缓存,一级缓存仍然默认开启,并在SQLSession内部运作。由于`select`标签在执行时不清理缓存,而`insert`, `update`, `delete`会自动清除,因此需要正确使用标签以避免缓存导致的查询错误。关键涉及类包括DefaultSqlSession和CachingExecutor。" 116293402,10553018,Oracle数据库IO问题分析与优化策略,"['Oracle数据库', 'IO优化', '数据库性能优化', '存储技术', 'SQL优化']
摘要由CSDN通过智能技术生成

最近碰到同事使用ibatis 和spring mvc,遇到了 update 后查询 结果为未update前的数据,但是事物整体操作结束后数据是成功update了。最初怀疑是spring的事物传播问题,以为是本类调用本类方法导致的.但是看了一下应用log,整体的sqlsession 的内存对象,链接是一个对象而且开启了事物,似乎事物传播没问题。又仔细看看了日志,发现查询ibatis只有第一次查询和update时是打印sql的,但是第二次查询没有打印sql,于是怀疑缓存的问题。但是看到ibatis xml 配置里 cache是禁用的,仔细查了下资料。原来ibatis是两级缓存,

第一级缓存只能是开启的,而且是每个sqlsession 内部的,可以在每个sql级别配置 是否启用或者清除,这正是导致第二次查询的结果是未更新的原因,因为直接查的内存中数据

1:localCache

<select id="cleanCache" resultType="long" useCache="false" flushCache="true">   
          select 1 from dual        
      </select>  运行这个sql 可以清除cache
2.第二级缓存是全局的,通过xml中配置<cache/> 生效


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值