解决hibernate中的懒加载(延迟加载)问题
解決hibernate中的懶加載(延遲加載)問題
我們在開發的時候經常會遇到延遲加載問題,在實體映射時,多對一和多對多中,多的一樣的屬性默認是lazy="true"(即,默認是延遲加載),
如:<many-to-one name="parent" class="Department" column="parentId"?lazy="true"/>
延遲加載表現在:比如:我們要查詢id為2的部門數據,但是有許多用戶數據的部門外鍵是id為2,我們在查詢的時候,由于默認lazy="true"(懶加載),所以是不會查詢部門外鍵為2的用戶數據的,但是我們在一次session中,不僅不要部門數據,而且還有可能需要該部門對應的用戶數據,由于默認設置為lazy="true",所以我們在一次session中是獲取不到該用戶數據了。
解決方法一:設置lazy="false"。該方法有很到缺點,效率極低,我們將所有相關聯的數據都查詢了,頻繁的查詢降低了效率!!不建議采用
方法二:使用OpenSessionInViewFilter攔截器,在web.xml中配置該攔截器
<filter>
?? <filter-name>OpenSessionInViewFilter</filter-name>
?? <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
? </filter>
??? <filter-mapping>
?? <filter-name>OpenSessionInViewFilter</filter-name>
? ?<url-pattern>*.do</url-pattern>
?? </filter-mapping>
該方法原理,使用該攔截器,將session一直開啟,不關閉,這時即使還是懶加載,但是session沒有關閉,依然可以使用session查詢相關數據,
???? 優點:只需要加載自己想要的數據,缺點:session一直在開啟,不安全
轉載于:https://www.cnblogs.com/w1217/p/5500300.html
總結
以上是生活随笔為你收集整理的解决hibernate中的懒加载(延迟加载)问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Mac MySQLdb模块安装,可算解决
- 下一篇: 又见链表 --- 另一种Creat方式与