一个 service 方法下的循环,应该是一个事务内。循环里对同一表先查再插,后面循环再查询无法读到最新数据,加了 flush 后好使了,这是怎么回事?一个事务内读不到最新数据?
1
BiChengfei 2023-07-13 10:00:50 +08:00
直接百度 bibernate flush ,有你要的回答
|
2
fmumu 2023-07-13 10:01:18 +08:00
好像是 flush 的时候才写的? 记不清了
可以把调试日志打开看看 sql |
3
miaeLKK OP 奇怪的是这代码没改过,之前一直没事,在我优化查询后就出现了。。。优化只是把一个要查询再写入大表清除了无用的数据,区别上感觉只是之前查询很慢,现在查询很快。难道时间长的循环就会落库,后来快了,时间短,就来不及落库?🤦😂
|
4
zoharSoul 2023-07-13 11:07:49 +08:00
保持简单 远离 hibernate /dog
|
5
knightdf 2023-07-13 11:27:36 +08:00
不 flush 怎么查的到
|
7
FreeEx 2023-07-13 11:39:34 +08:00
别用 hibernate ,生命周期挺烦人的。
有时候你写了 save 不更新,但是修改对象属性的时候自动更新了,总之就是反常识,反人类,不要用。 |
8
jeffh 2023-07-13 12:15:31 +08:00
我的评价是:hibernate 不如 mybatis plus
|
9
yoloMiss 2023-07-24 19:57:18 +08:00
一个事务中必须得要先 flush ,然后才能拿到。不过,貌似我记得这个东西是可以修改配置的,只要 save 了,默认 flush 。
不过,你要是写过原生的 jdbc 提交,每次查询或者插入、更新,删除动作都要手动创建 sqlsession 的,那你就会回头感叹,hibernate 真香。😂 |