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