解決spring jpa中update的坑
使用jpa 自己編寫update語句,
遇到問題:1.在同一個service事物中,先執(zhí)行保存,在執(zhí)行更新,緊接著執(zhí)行查詢--查詢結(jié)果為更新前的結(jié)果。
2.執(zhí)行自定義update方法結(jié)束后執(zhí)行查詢查出結(jié)果依然為update前的結(jié)果集
解決問題所在:自定義update并未清空實(shí)體緩存。注解@Modifying加參數(shù)eg:@Modifying(clearAutomatically = true)
jpa更新問題記錄使用jpa 去更新:@Modifying(clearAutomatically = true),@Transactional
它說的是可以清除底層持久化上下文,就是entityManager這個類,我們知道jpa底層實(shí)現(xiàn)會有二級緩存,也就是在更新完數(shù)據(jù)庫后,如果后面去用這個對象,你再去查這個對象,這個對象是在一級緩存,但是并沒有跟數(shù)據(jù)庫同步,這個時候用clearAutomatically=true,就會刷新hibernate的一級緩存了, 不然你在同一接口中,更新一個對象,接著查詢這個對象,那么你查出來的這個對象還是之前的沒有更新之前的狀態(tài)。
注意:如果說在同個事務(wù)方法中,如果有多個更新操作,使用@Modifying(clearAutomatically = true),就會產(chǎn)生在此之前的update操作全部失效,因為把jpa的一級緩存都刷新掉了
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Nginx+php配置文件及原理解析2. Intellij IDEA 2019 最新亂碼問題及解決必殺技(必看篇)3. Android Manifest中meta-data擴(kuò)展元素數(shù)據(jù)的配置與獲取方式4. java中throws實(shí)例用法詳解5. CSS3實(shí)現(xiàn)動態(tài)翻牌效果 仿百度貼吧3D翻牌一次動畫特效6. 關(guān)于HTML5的img標(biāo)簽7. Android自定義View實(shí)現(xiàn)掃描效果8. PHP5.0正式發(fā)布 不完全兼容PHP4 新增多項功能9. css3溢出隱藏的方法10. ASP.NET MVC獲取多級類別組合下的產(chǎn)品
