數(shù)據(jù)庫結(jié)構(gòu)如下
strategy中有外鍵member_id(關(guān)聯(lián)member表)外鍵strategy_category(關(guān)聯(lián)category表)而member表中有外鍵position_id(關(guān)聯(lián)positons表)
如果前臺頁面直接查詢stategy表中內(nèi)容我們hql語句如果這么寫
stringhql="fromstrategywhereid=:id";
控制臺會報nosession錯誤這是因為hibernate默認懶加載只有我們需要的時候才會將關(guān)聯(lián)的對象加載出來這里在我們前臺需要取關(guān)聯(lián)對象中的屬性的時候session已經(jīng)關(guān)閉了額才會報這樣的錯誤
那么如何解決呢
這里建議使用leftjoinfetch的方式來加載對象而不是將注解中默認的懶加載改為急迫加載效率會很低
語句如下
1
2
3
4
5
|
strategystrategy=(strategy)sessionfactoryutil.getsession() .createquery( "fromstrategysleftjoinfetchs.strategycategoryleftjoinfetchs.memberleftjoinfetchs.member.positionswheres.id=:id" ) .setinteger( "id" ,id).uniqueresult(); |
這里需要注意的是因為關(guān)聯(lián)的member表中又關(guān)聯(lián)了positions表所以需要一并加載出來另一個需要注意的是這里的s.id必須這么寫因為這里的每張表的主鍵名都為id如果不指明系統(tǒng)無法辨識
總結(jié)
以上就是本文關(guān)于淺談hibernate急迫加載問題(多重外鍵關(guān)聯(lián))的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
原文鏈接:http://blog.csdn.net/islandww/article/details/78610914