首頁 > 軟體

Mybatis載入策略的實現方法

2022-02-24 19:02:12

MaBatis載入策略

1.什麼是延遲載入

Mybatis中一對一,一對多,多對多關係的設定及實現,可以實現物件的關聯查詢。實際開發過程中很多時候我們並不需要總是在載入使用者資訊時就一定要載入他的訂單資訊。此時就是我們所說的延遲載入。

例如:

問題1:在一對多中,當我們有一個使用者,它有個100個訂單在查詢使用者的時候,要不要把關聯的訂單查出來?

  • 回答:在查詢使用者時,使用者下的訂單應該是,什麼時候用,什麼時候查詢。(一對多)

**問題2:**在查詢訂單的時候,要不要把關聯的使用者查出來?

  • 在查詢訂單時,訂單所屬的使用者資訊應該是隨著訂單一起查詢出來。(多對一) 1.1延遲載入

就是在需要用到資料時才進行載入,不需要用到資料時就不載入資料。延遲載入也稱懶載入。

注意:

延遲載入是基於巢狀查詢來實現的

  • 優點:

先從單表查詢,需要時再從關聯表去關聯查詢,大大提高資料庫效能,因為查詢單表要比關聯查詢多張表
速度要快。

  • 缺點:

因為只有當需要用到資料時,才會進行資料庫查詢,這樣在大批次資料查詢時,因為查詢工作也要消耗時
間,所以可能造成使用者等待時間變長,造成使用者體驗下降。

  • 在多表中:

一對多,多對多:通常情況下采用延遲載入
一對一(多對一):通常情況下采用立即載入

1.2實現

1.2.1 區域性延遲載入

在association和collection標籤中都有一個fetchType屬性,通過修改它的值,可以修改區域性的載入策略。

xml組態檔:

<!--
巢狀查詢:查詢使用者所對應的訂單
-->
    <resultMap id="getUserInfoWithNested" type="user">
        <id property="id" column="id"></id>
        <result property="username" column="username"></result>
        <result property="birthday" column="birthday"></result>
        <result property="sex" column="sex"></result>
        <result property="address" column="address"></result>
        <!--
        fetchType="lazy" 懶載入策略
        fetchType="eager" 立即載入策略
    -->
        <collection property="ordersList" ofType="com.lagou.domain.Orders" select="com.lagou.mapper.OrdersMapper.findUserAllOrder" column="id" fetchType="lazy" ></collection>
    </resultMap>
    <select id="findUserOrder2" resultMap="getUserInfoWithNested">
        select * from user
    </select>

1.2.2 設定觸發延遲載入的方法

  • 大家在設定了延遲載入策略後,發現即使沒有呼叫關聯物件的任何方法,但是在你呼叫當前物件的equals、clone、hashCode、toString方法時也會觸發關聯物件的查詢。
  • 我們可以在組態檔中使用lazyLoadTriggerMethods設定項覆蓋掉上面四個方法。
<!--    設定延遲載入策略-->
    <settings>
		<!--        所有方法都會延遲載入-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
    </settings>

1.2.3全域性延遲載入

  • 引入全域性延遲載入,目的是解放區域性延遲載入在標籤collection中加入一直家fetchType引數。從而可以做到所有的巢狀查詢是實現全域性延遲載入。
  • 在Mybatis的核心組態檔中可以使用setting標籤修改全域性的載入策略。
<settings>
<!--        所有方法都會延遲載入-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
        <!--開啟全域性延遲載入功能-->
        <setting name="lazyLoadingEnabled" value="true"/>
    </settings>

注意:區域性的載入策略優先順序高於全域性的載入策略。

訂單沒有被查詢出來:

到此這篇關於Mybatis載入策略的文章就介紹到這了,更多相關Mybatis載入策略內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com