Mybatis延遲加載的實(shí)現(xiàn)方式
1、概念:
MyBatis中的延遲加載,也稱為懶加載,是指在進(jìn)行表的關(guān)聯(lián)查詢時(shí),按照設(shè)置延遲規(guī)則推遲對(duì)關(guān)聯(lián)對(duì)象的select查詢。例如在進(jìn)行一對(duì)多查詢的時(shí)候,只查詢出一方,當(dāng)程序中需要多方的數(shù)據(jù)時(shí),mybatis再發(fā)出sql語(yǔ)句進(jìn)行查詢,這樣子延遲加載就可以的減少數(shù)據(jù)庫(kù)壓力。MyBatis 的延遲加載只是對(duì)關(guān)聯(lián)對(duì)象的查詢有遲延設(shè)置,對(duì)于主加載對(duì)象都是直接執(zhí)行查詢語(yǔ)句的。
2、加載時(shí)機(jī):
直接加載:執(zhí)行完對(duì)主加載對(duì)象的 select 語(yǔ)句,馬上執(zhí)行對(duì)關(guān)聯(lián)對(duì)象的 select 查詢。侵入式延遲: 執(zhí)行對(duì)主加載對(duì)象的查詢時(shí),不會(huì)執(zhí)行對(duì)關(guān)聯(lián)對(duì)象的查詢。但當(dāng)要訪問主加載對(duì)象的詳情屬性時(shí),就會(huì)馬上執(zhí)行關(guān)聯(lián)對(duì)象的select查詢。深度延遲: 執(zhí)行對(duì)主加載對(duì)象的查詢時(shí),不會(huì)執(zhí)行對(duì)關(guān)聯(lián)對(duì)象的查詢。訪問主加載對(duì)象的詳情時(shí)也不會(huì)執(zhí)行關(guān)聯(lián)對(duì)象的select查詢。只有當(dāng)真正訪問關(guān)聯(lián)對(duì)象的詳情時(shí),才會(huì)執(zhí)行對(duì)關(guān)聯(lián)對(duì)象的 select 查詢。
注意:延遲加載的應(yīng)用要求:關(guān)聯(lián)對(duì)象的查詢與主加載對(duì)象的查詢必須是分別進(jìn)行的select語(yǔ)句,不能是使用多表連接所進(jìn)行的select查詢。因?yàn)椋啾磉B接查詢,實(shí)質(zhì)是對(duì)一張表的查詢,對(duì)由多個(gè)表連接后形成的一張表的查詢。會(huì)一次性將多張表的所有信息查詢出來。
3、侵入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置侵入式加載
<!--開啟延遲加載-->
<setting name="lazyLoadingEnabled" value="true"/>
<!--配置侵入式延遲加載 默認(rèn)為false(深度加載)
侵入式:默認(rèn)只會(huì)執(zhí)行主加載SQL,那么當(dāng)訪問主加載對(duì)象的詳細(xì)信息時(shí)才會(huì)執(zhí)行關(guān)聯(lián)對(duì)象的SQL查詢
深度延遲:默認(rèn)只執(zhí)行主加載SQL,那么當(dāng)調(diào)用到主加載對(duì)象中關(guān)聯(lián)對(duì)象的信息時(shí)才會(huì)執(zhí)行關(guān)聯(lián)對(duì)象的SQL查詢
-->
<setting name="aggressiveLazyLoading" value="true"/>
②、不調(diào)用主加載對(duì)象時(shí)只有一條SQL


③、調(diào)用主加載對(duì)象的信息時(shí)會(huì)產(chǎn)生兩條SQL


4、深入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置深度加載
<!--開啟延遲加載-->
<setting name="lazyLoadingEnabled" value="true"/>
<!--配置侵入式延遲加載 默認(rèn)為false(深度加載)
侵入式:默認(rèn)只會(huì)執(zhí)行主加載SQL,那么當(dāng)訪問主加載對(duì)象的詳細(xì)信息時(shí)才會(huì)執(zhí)行關(guān)聯(lián)對(duì)象的SQL查詢
深度延遲:默認(rèn)只執(zhí)行主加載SQL,那么當(dāng)調(diào)用到主加載對(duì)象中關(guān)聯(lián)對(duì)象的信息時(shí)才會(huì)執(zhí)行關(guān)聯(lián)對(duì)象的SQL查詢
-->
<setting name="aggressiveLazyLoading" value="false"/>
②、調(diào)用主加載對(duì)象時(shí)不會(huì)執(zhí)行第二條加載SQL


③、調(diào)用關(guān)聯(lián)對(duì)象詳細(xì)信息時(shí)會(huì)執(zhí)行第二次查詢


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java圖形化編程之JFrame疫苗接種系統(tǒng)詳解
GUI圖形界面設(shè)計(jì)是用戶和程序交互的工具,用戶通過圖形界面控制程序事件的發(fā)生。首先介紹Swing的基本體系結(jié)構(gòu),這是底層2021-09-09
java必學(xué)必會(huì)之this關(guān)鍵字
java必學(xué)必會(huì)之this關(guān)鍵字,java中this的用法進(jìn)行了詳細(xì)的分析介紹,感興趣的小伙伴們可以參考一下2015-12-12
MyBatis XML方式的基本用法之多表查詢功能的示例代碼
這篇文章主要介紹了MyBatis XML方式的基本用法之多表查詢功能的示例代碼,本文通過示例文字相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07
如何使用IDEA2022.1?創(chuàng)建Spring?Boot項(xiàng)目
這篇文章主要介紹了如何使用IDEA2022.1?創(chuàng)建Spring?Boot項(xiàng)目,大家在使用idea開發(fā)工具時(shí)發(fā)現(xiàn)給以往的版本略微的不同,細(xì)心的小編在此記錄下,需要的朋友可以參考下2022-08-08
java循環(huán)刪除List元素報(bào)錯(cuò)的原因分析與解決
大家在工作中應(yīng)該都會(huì)遇到從List集合中刪除某一個(gè)或多個(gè)元素的業(yè)務(wù)場(chǎng)景,相信大家都會(huì)避開在循環(huán)里面刪除元素,使用其他方式處理,這是為什么呢,下面小編就來和大家詳細(xì)聊聊2023-11-11
Java使用DateFormatter格式化日期時(shí)間的方法示例
這篇文章主要介紹了Java使用DateFormatter格式化日期時(shí)間的方法,結(jié)合具體實(shí)例分析了java使用DateFormatter格式化日期時(shí)間的相關(guān)操作技巧,需要的朋友可以參考下2017-04-04
SpringBoot3通過GraalVM生成exe執(zhí)行文件問題
文章介紹了如何安裝GraalVM和Visual Studio,并通過Spring Boot項(xiàng)目將Java應(yīng)用程序封裝成可執(zhí)行文件(.exe)2024-12-12
使用 Redis 緩存實(shí)現(xiàn)點(diǎn)贊和取消點(diǎn)贊的示例代碼
這篇文章主要介紹了使用 Redis 緩存實(shí)現(xiàn)點(diǎn)贊和取消點(diǎn)贊的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03

