一个 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 真香。 |