Mybatis加載策略的實現(xiàn)方法
MaBatis加載策略
1.什么是延遲加載
Mybatis中一對一,一對多,多對多關(guān)系的配置及實現(xiàn),可以實現(xiàn)對象的關(guān)聯(lián)查詢。實際開發(fā)過程中很多時候我們并不需要總是在加載用戶信息時就一定要加載他的訂單信息。此時就是我們所說的延遲加載。
例如:
問題1:在一對多中,當(dāng)我們有一個用戶,它有個100個訂單在查詢用戶的時候,要不要把關(guān)聯(lián)的訂單查出來?
- 回答:在查詢用戶時,用戶下的訂單應(yīng)該是,什么時候用,什么時候查詢。(一對多)
**問題2:**在查詢訂單的時候,要不要把關(guān)聯(lián)的用戶查出來?
- 在查詢訂單時,訂單所屬的用戶信息應(yīng)該是隨著訂單一起查詢出來。(多對一) 1.1延遲加載
就是在需要用到數(shù)據(jù)時才進(jìn)行加載,不需要用到數(shù)據(jù)時就不加載數(shù)據(jù)。延遲加載也稱懶加載。
注意:
延遲加載是基于嵌套查詢來實現(xiàn)的
- 優(yōu)點:
先從單表查詢,需要時再從關(guān)聯(lián)表去關(guān)聯(lián)查詢,大大提高數(shù)據(jù)庫性能,因為查詢單表要比關(guān)聯(lián)查詢多張表
速度要快。
- 缺點:
因為只有當(dāng)需要用到數(shù)據(jù)時,才會進(jìn)行數(shù)據(jù)庫查詢,這樣在大批量數(shù)據(jù)查詢時,因為查詢工作也要消耗時
間,所以可能造成用戶等待時間變長,造成用戶體驗下降。
- 在多表中:
一對多,多對多:通常情況下采用延遲加載
一對一(多對一):通常情況下采用立即加載
1.2實現(xiàn)
1.2.1 局部延遲加載
在association和collection標(biāo)簽中都有一個fetchType屬性,通過修改它的值,可以修改局部的加載策略。
xml配置文件:
<!--
嵌套查詢:查詢用戶所對應(yīng)的訂單
-->
<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 設(shè)置觸發(fā)延遲加載的方法
- 大家在配置了延遲加載策略后,發(fā)現(xiàn)即使沒有調(diào)用關(guān)聯(lián)對象的任何方法,但是在你調(diào)用當(dāng)前對象的equals、clone、hashCode、toString方法時也會觸發(fā)關(guān)聯(lián)對象的查詢。
- 我們可以在配置文件中使用lazyLoadTriggerMethods配置項覆蓋掉上面四個方法。
<!-- 設(shè)置延遲加載策略-->
<settings>
<!-- 所有方法都會延遲加載-->
<setting name="lazyLoadTriggerMethods" value="toString()"/>
</settings>1.2.3全局延遲加載
- 引入全局延遲加載,目的是解放局部延遲加載在標(biāo)簽collection中加入一直家fetchType參數(shù)。從而可以做到所有的嵌套查詢是實現(xiàn)全局延遲加載。
- 在Mybatis的核心配置文件中可以使用setting標(biāo)簽修改全局的加載策略。
<settings>
<!-- 所有方法都會延遲加載-->
<setting name="lazyLoadTriggerMethods" value="toString()"/>
<!--開啟全局延遲加載功能-->
<setting name="lazyLoadingEnabled" value="true"/>
</settings>注意:局部的加載策略優(yōu)先級高于全局的加載策略。
訂單沒有被查詢出來:

到此這篇關(guān)于Mybatis加載策略的文章就介紹到這了,更多相關(guān)Mybatis加載策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker?快速部署Springboot項目超詳細(xì)最新版
這篇文章主要介紹了Docker?快速部署Springboot項目超詳細(xì)最新版的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
java jdk1.8 使用stream流進(jìn)行l(wèi)ist 分組歸類操作
這篇文章主要介紹了java jdk1.8 使用stream流進(jìn)行l(wèi)ist 分組歸類操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
java?WebSocket?服務(wù)端實現(xiàn)代碼
WebSocket協(xié)議是基于TCP的一種新的網(wǎng)絡(luò)協(xié)議。它實現(xiàn)了瀏覽器與服務(wù)器全雙工(full-duplex)通信——允許服務(wù)器主動發(fā)送信息給客戶端,這篇文章主要介紹了java?WebSocket?服務(wù)端代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02
SpringBoot使用Quartz無法注入Bean的問題及解決
這篇文章主要介紹了SpringBoot使用Quartz無法注入Bean的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
Java核心編程之文件隨機(jī)讀寫類RandomAccessFile詳解
這篇文章主要為大家詳細(xì)介紹了Java核心編程之文件隨機(jī)讀寫類RandomAccessFile,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
Mybatis之解決collection一對多問題(顯示的結(jié)果沒有整合到一起)
這篇文章主要介紹了Mybatis之解決collection一對多問題(顯示的結(jié)果沒有整合到一起),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03

