hibernate学习笔记5--session.flush()

本文解释了Hibernate中默认的CRUD操作顺序及其背后的原因,并介绍了如何通过使用session.flush()来调整这些操作的执行顺序。
我们知道hibernate默认情况下对CRUD的执行是按照save、update、delete的顺序,为什么是这样呢?
因为在调用session.save()时,hibernate同时执行了session.flush(),这个方法是清理(注意不是清空!)hibernate缓存,同时发送SQL语句到数据库(但并没有更新数据库,直到commit()后才更新)。
代码:

session.save(user);//此时会输出SQL语句


session.update(user);//不输出SQL语句


session.delete(user);//不输出SQL语句


关键在于调用session.save()时,hibernate替我们执行了session.flush()。
那么如果我们想要改变hibernate的CRUD执行顺序,这时session.flush()就派上用场了:

session.update(user1);
session.flush();
session.save(user2);

这样就会按照update、save的顺序执行。
: Request Parameters: {"requestBody":"{\"number\":\"7777776999\",\"xiadan\":\"2025-09-18\",\"jiaohuo\":\"\"}"} 2025-09-18T10:48:58.761+08:00 ERROR 19496 --- [p-nio-80-exec-1] org.hibernate.AssertionFailure : HHH000099: an assertion failure occurred (this may indicate a bug in Hibernate, but is more likely due to unsafe use of the session): org.hibernate.AssertionFailure: null id in com.kucun.entity.Dingdan entry (don't flush the Session after an exception occurs) 2025-09-18T10:48:58.773+08:00 ERROR 19496 --- [p-nio-80-exec-1] c.k.d.validation.UniqueEntityValidator : Error validating entity uniqueness org.hibernate.AssertionFailure: null id in com.kucun.entity.Dingdan entry (don't flush the Session after an exception occurs) at org.hibernate.event.internal.DefaultFlushEntityEventListener.checkId(DefaultFlushEntityEventListener.java:81) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.internal.DefaultFlushEntityEventListener.getValues(DefaultFlushEntityEventListener.java:175) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.internal.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:134) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.service.internal.EventListenerGroupImpl.fireEventOnEachListener(EventListenerGroupImpl.java:127) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.internal.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:227) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.internal.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:90) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.internal.DefaultAutoFlushEventListener.onAutoFlush(DefaultAutoFlushEventListener.java:48) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.event.service.internal.EventListenerGroupImpl.fireEventOnEachListener(EventListenerGroupImpl.java:127) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.internal.SessionImpl.autoFlushIfRequired(SessionImpl.java:1375) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.query.sqm.internal.ConcreteSqmSelectQueryPlan.lambda$new$0(ConcreteSqmSelectQueryPlan.java:108) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.query.sqm.internal.ConcreteSqmSelectQueryPlan.withCacheableSqmInterpretation(ConcreteSqmSelectQueryPlan.java:303) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final] at org.hibernate.query.sqm.internal.ConcreteSqmSelectQueryPlan.performList(ConcreteSqmSelectQueryPlan.java:244) ~[hibernate-core-6.2.20.Final.jar:6.2.20.Final]
最新发布
09-19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值