數據庫結構如下
strategy中有外鍵member_id(關聯member表)外鍵strategy_category(關聯category表)而member表中有外鍵position_id(關聯positons表)
如果前臺頁面直接查詢stategy表中內容我們hql語句如果這么寫
Stringhql="FromStrategywhereid=:id";
控制臺會報nosession錯誤這是因為hibernate默認懶加載只有我們需要的時候才會將關聯的對象加載出來這里在我們前臺需要取關聯對象中的屬性的時候session已經關閉了額才會報這樣的錯誤
那么如何解決呢
這里建議使用leftjoinfetch的方式來加載對象而不是將注解中默認的懶加載改為急迫加載效率會很低
語句如下
Strategystrategy=(Strategy)sessionFactoryUtil.getSession().createQuery("FromStrategysleftjoinfetchs.strategyCategoryleftjoinfetchs.memberleftjoinfetchs.member.positionswheres.id=:id").setInteger("id",id).uniqueResult();
這里需要注意的是因為關聯的member表中又關聯了positions表所以需要一并加載出來另一個需要注意的是這里的s.id必須這么寫因為這里的每張表的主鍵名都為id如果不指明系統無法辨識
總結
以上就是本文關于淺談hibernate急迫加載問題(多重外鍵關聯)的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
新聞熱點
疑難解答
圖片精選