hibernate session的flushMode的区别

本文详细介绍了Hibernate中的FlushMode设置及其不同选项如何影响数据同步到数据库的行为。特别是对比了AUTO、COMMIT、NEVER和ALWAYS等模式,并强调了在NEVER模式下确保数据一致性的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里面的清理缓存可以理解为hibernate自动执行了一次 session.flush();
选择什么样的flush mode就是采取对hibernate session采取什么样的数据刷新的策略。
Session.setFlushMode()用于设定清理缓存的时间点。

对比一下几种flush mode:

FlushMode.AUTO:
调用Session的查询方法时,清理缓存,注意:这条规则必须保证显式开启的事务中,对于outside a transaction
调用Session.commit()时,清理缓存
调用Session.flush()时,清理缓存

FlushMode.COMMIT:
调用Session的查询方法时,不清理缓存
调用Session.commit()时,清理缓存
调用Session.flush()时,清理缓存

FlushMode.NEVER(MANUAL):
调用Session的查询方法时,不清理缓存
调用Session.commit()时,不清理缓存
调用Session.flush()时,清理缓存

FlushMode.ALWAYS:测试未发现和auto有什么区别。
调用Session的查询方法时,清理缓存,注意:这条规则必须保证显式开启的事务中,对于outside a transaction
调用Session.commit()时,清理缓存

调用Session.flush()时,清理缓存

三种情况分别在以下时机同步数据库
session.flushmode=manual
1.只有手动调用flush()

session.flushmode=commit
1.手动调用flush()
2.commit()时候

session.flushmode=auto
1.手动调用flush()
2.commit()时候

3.查询前 (经过测试(Oracle驱动),必须在事务内,不确定是否全部情形)

对比一下,请注意FlushMode.NEVER
如果在调用Session的查询方法之前,不清理缓存,那么就会引入脏数据
所以会有那一步
session.flush(); // who know’s what been done till now
在FlushMode.NEVER之前,将缓存清理,保证数据正确。

在文中最后一段程序中:
将FlushMode.NEVER夹在两个session.flush()之间,就保证在不清理缓存的情况,数据的一致性。

下面的文章值得一看。

《了解Hibernate的FlushMode.NEVER模式》

http://www.51cto.com/specbook/229/34023.htm

http://www2.matrix.org.cn/resource/article/2006-10-08/Hibernate+FlushMode+NEVER_312bca85-5699-11db-91a0-d98dff0aec60.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡搜偶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值