您好,登錄后才能下訂單哦!
這篇文章給大家介紹Mybatis中怎么實現延遲加載,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
1、概念:
MyBatis中的延遲加載,也稱為懶加載,是指在進行表的關聯查詢時,按照設置延遲規則推遲對關聯對象的select查詢。例如在進行一對多查詢的時候,只查詢出一方,當程序中需要多方的數據時,mybatis再發出sql語句進行查詢,這樣子延遲加載就可以的減少數據庫壓力。MyBatis 的延遲加載只是對關聯對象的查詢有遲延設置,對于主加載對象都是直接執行查詢語句的。
2、加載時機:
直接加載:執行完對主加載對象的 select 語句,馬上執行對關聯對象的 select 查詢。侵入式延遲: 執行對主加載對象的查詢時,不會執行對關聯對象的查詢。但當要訪問主加載對象的詳情屬性時,就會馬上執行關聯對象的select查詢。深度延遲: 執行對主加載對象的查詢時,不會執行對關聯對象的查詢。訪問主加載對象的詳情時也不會執行關聯對象的select查詢。只有當真正訪問關聯對象的詳情時,才會執行對關聯對象的 select 查詢。
注意:延遲加載的應用要求:關聯對象的查詢與主加載對象的查詢必須是分別進行的select語句,不能是使用多表連接所進行的select查詢。因為,多表連接查詢,實質是對一張表的查詢,對由多個表連接后形成的一張表的查詢。會一次性將多張表的所有信息查詢出來。
3、侵入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置侵入式加載
<!--開啟延遲加載--> <setting name="lazyLoadingEnabled" value="true"/> <!--配置侵入式延遲加載 默認為false(深度加載) 侵入式:默認只會執行主加載SQL,那么當訪問主加載對象的詳細信息時才會執行關聯對象的SQL查詢 深度延遲:默認只執行主加載SQL,那么當調用到主加載對象中關聯對象的信息時才會執行關聯對象的SQL查詢 --> <setting name="aggressiveLazyLoading" value="true"/>
②、不調用主加載對象時只有一條SQL
③、調用主加載對象的信息時會產生兩條SQL
4、深入式延遲加載:
①、Mybatis-config.xml大配置文件,首先開啟延遲加載,然后再配置深度加載
<!--開啟延遲加載--> <setting name="lazyLoadingEnabled" value="true"/> <!--配置侵入式延遲加載 默認為false(深度加載) 侵入式:默認只會執行主加載SQL,那么當訪問主加載對象的詳細信息時才會執行關聯對象的SQL查詢 深度延遲:默認只執行主加載SQL,那么當調用到主加載對象中關聯對象的信息時才會執行關聯對象的SQL查詢 --> <setting name="aggressiveLazyLoading" value="false"/>
②、調用主加載對象時不會執行第二條加載SQL
③、調用關聯對象詳細信息時會執行第二次查詢
關于Mybatis中怎么實現延遲加載就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。