ibatis 一级缓存和二级缓存 遇到的问题,更新后查询问题
2016-07-12 16:52
495 查看
最近碰到同事使用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/> 生效
有的人遇到此问题在禁用二级缓存的情况下,可能会使用手动运行一下cleanCache的sql,但实际上这个不是根本,更本的原因是,他们在写mapper.xml时 在做 insert,update,delete操作 使用的是 select 标签。这个select 标签在执行时是不清除一级和二级缓存的,只有insert,update,delete标签 运行时会自动清除一级和二级缓存。
关键入口类 :org.apache.ibatis.session.defaults.DefaultSqlSession
org.apache.ibatis.executor.BaseExecutor,CachingExecutor
配置里 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/> 生效
有的人遇到此问题在禁用二级缓存的情况下,可能会使用手动运行一下cleanCache的sql,但实际上这个不是根本,更本的原因是,他们在写mapper.xml时 在做 insert,update,delete操作 使用的是 select 标签。这个select 标签在执行时是不清除一级和二级缓存的,只有insert,update,delete标签 运行时会自动清除一级和二级缓存。
关键入口类 :org.apache.ibatis.session.defaults.DefaultSqlSession
org.apache.ibatis.executor.BaseExecutor,CachingExecutor
相关文章推荐
- 页面缓存:内存和文件之间的那些事
- 浅析SQL Server中的执行计划缓存(上)
- Enterprise Library for .NET Framework 2.0缓存使用实例
- PowerShell中编程清空IE缓存方法
- PowerShell中使用.NET将程序集加入全局程序集缓存
- C#中缓存的基本用法总结
- Android实现图片异步加载并缓存到本地
- wap开发中如何有效的利用缓存减少消息的传送量
- PHP基于文件存储实现缓存的方法
- smarty缓存用法分析
- 在ASP.NET 2.0中操作数据之五十九:使用SQL缓存依赖项SqlCacheDependency
- 在ASP.NET 2.0中操作数据之五十八:在程序启动阶段缓存数据
- 在ASP.NET 2.0中操作数据之五十七:在分层架构中缓存数据
- 引用全局程序集缓存内的程序集的方法
- asp Response.flush 实时显示进度
- C#实现清除IE浏览器缓存的方法
- ASP.NET缓存管理的几种方法
- PHP文件缓存类实现代码
- 清除aspx页面缓存的程序实现方法
- C#缓存之SqlCacheDependency用法实例总结