最近碰到同事使用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/> 生效