请教一下hibernate缓存如何同数据库保持同步

night__cat 2008-07-01 11:17:53
当数据库记录由外部发生改变时,一级缓存session如何和数据库保持同步,而二级缓存又如何同数据库保持同步
...全文
801 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
Landor2004 2008-07-02
  • 打赏
  • 举报
回复
[Quote=引用楼主 night__cat 的帖子:]
当数据库记录由外部发生改变时,一级缓存session如何和数据库保持同步,而二级缓存又如何同数据库保持同步
[/Quote]

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

也就是这样,在前面加上 s.setCacheMode(CacheMode.REFRESH);
westsum 2008-07-01
  • 打赏
  • 举报
回复
所谓一级缓存,就是指Session对像中有持久对像的快照,当这个对像在外部发生成变化,在调用过SaveOrUpdate方法后,并不马上执行更新,而是在Session关闭时检查属性如果和快照中不一致,就去更新数据库,在配置文件中还可以指定如果属性发生变化才更新,也可以说是只更新发生变化了的属性。这样做可以提高效率。
seeSkyblue 2008-07-01
  • 打赏
  • 举报
回复
Session s = HibernateStore.getSession();
s.flush(); //强制同步
ldy214 2008-07-01
  • 打赏
  • 举报
回复
不懂 学习
Landor2004 2008-07-01
  • 打赏
  • 举报
回复
你可以以用refresh来刷新,你的缓存
liujie616 2008-07-01
  • 打赏
  • 举报
回复
当你调用COMMIT()的时候,就会刷新缓存。

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧