当你调用COMMIT()的时候,就会刷新缓存。

解决方案 »

  1.   

    你可以以用refresh来刷新,你的缓存
      

  2.   

    Session s = HibernateStore.getSession();
    s.flush(); //强制同步
      

  3.   

    所谓一级缓存,就是指Session对像中有持久对像的快照,当这个对像在外部发生成变化,在调用过SaveOrUpdate方法后,并不马上执行更新,而是在Session关闭时检查属性如果和快照中不一致,就去更新数据库,在配置文件中还可以指定如果属性发生变化才更新,也可以说是只更新发生变化了的属性。这样做可以提高效率。
      

  4.   

    http://blog.csdn.net/caoyinghui1986/archive/2008/04/20/2308993.aspx
      

  5.   


    如果查询需要强行刷新其查询缓存区域,那么你应该调用Query.setCacheMode(CacheMode.REFRESH)方法。 这对在其他进程中修改底层数据(例如,不通过Hibernate修改数据),或对那些需要选择性更新特定查询结果集的情况特别有用。 这是对SessionFactory.evictQueries()的更为有效的替代方案,同样可以清除查询缓存区域。 也就是这样,在前面加上 s.setCacheMode(CacheMode.REFRESH);