Mybatis延遲加載的實現(xiàn)方式
1、概念:
MyBatis中的延遲加載,也稱為懶加載,是指在進行表的關聯(lián)查詢時,按照設置延遲規(guī)則推遲對關聯(lián)對象的select查詢。例如在進行一對多查詢的時候,只查詢出一方,當程序中需要多方的數(shù)據(jù)時,mybatis再發(fā)出sql語句進行查詢,這樣子延遲加載就可以的減少數(shù)據(jù)庫壓力。MyBatis 的延遲加載只是對關聯(lián)對象的查詢有遲延設置,對于主加載對象都是直接執(zhí)行查詢語句的。
2、加載時機:
直接加載:執(zhí)行完對主加載對象的 select 語句,馬上執(zhí)行對關聯(lián)對象的 select 查詢。侵入式延遲: 執(zhí)行對主加載對象的查詢時,不會執(zhí)行對關聯(lián)對象的查詢。但當要訪問主加載對象的詳情屬性時,就會馬上執(zhí)行關聯(lián)對象的select查詢。深度延遲: 執(zhí)行對主加載對象的查詢時,不會執(zhí)行對關聯(lián)對象的查詢。訪問主加載對象的詳情時也不會執(zhí)行關聯(lián)對象的select查詢。只有當真正訪問關聯(lián)對象的詳情時,才會執(zhí)行對關聯(lián)對象的 select 查詢。
注意:延遲加載的應用要求:關聯(lián)對象的查詢與主加載對象的查詢必須是分別進行的select語句,不能是使用多表連接所進行的select查詢。因為,多表連接查詢,實質(zhì)是對一張表的查詢,對由多個表連接后形成的一張表的查詢。會一次性將多張表的所有信息查詢出來。
3、侵入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置侵入式加載
<!--開啟延遲加載--> <setting name="lazyLoadingEnabled" value="true"/> <!--配置侵入式延遲加載 默認為false(深度加載) 侵入式:默認只會執(zhí)行主加載SQL,那么當訪問主加載對象的詳細信息時才會執(zhí)行關聯(lián)對象的SQL查詢 深度延遲:默認只執(zhí)行主加載SQL,那么當調(diào)用到主加載對象中關聯(lián)對象的信息時才會執(zhí)行關聯(lián)對象的SQL查詢 --> <setting name="aggressiveLazyLoading" value="true"/>
②、不調(diào)用主加載對象時只有一條SQL
③、調(diào)用主加載對象的信息時會產(chǎn)生兩條SQL
4、深入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置深度加載
<!--開啟延遲加載--> <setting name="lazyLoadingEnabled" value="true"/> <!--配置侵入式延遲加載 默認為false(深度加載) 侵入式:默認只會執(zhí)行主加載SQL,那么當訪問主加載對象的詳細信息時才會執(zhí)行關聯(lián)對象的SQL查詢 深度延遲:默認只執(zhí)行主加載SQL,那么當調(diào)用到主加載對象中關聯(lián)對象的信息時才會執(zhí)行關聯(lián)對象的SQL查詢 --> <setting name="aggressiveLazyLoading" value="false"/>
②、調(diào)用主加載對象時不會執(zhí)行第二條加載SQL
③、調(diào)用關聯(lián)對象詳細信息時會執(zhí)行第二次查詢
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java中的System類、BigInteger類和BigDecimal類詳解
這篇文章主要介紹了Java中的System類、BigInteger類和BigDecimal類詳解,arraycopy()方法,復制數(shù)組元素,比較適合底層調(diào)用,一般使用Arrays.copyOf()完成復制數(shù)組,需要的朋友可以參考下2023-09-09Java如何實現(xiàn)微信支付v3的支付回調(diào)
這篇文章主要給大家介紹了關于Java如何實現(xiàn)微信支付v3的支付回調(diào),微信實現(xiàn)支付功能與支付寶實現(xiàn)支付功能是相似的,文中給了詳細的示例代碼,需要的朋友可以參考下2023-07-07Java并發(fā)編程學習之ThreadLocal源碼詳析
這篇文章主要給大家介紹了關于Java并發(fā)編程學習之源碼分析ThreadLocal的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-06-06