91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis中怎么實現延遲加載

發布時間:2021-08-06 17:06:39 來源:億速云 閱讀:324 作者:Leah 欄目:編程語言

這篇文章給大家介紹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中怎么實現延遲加載就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永善县| 修文县| 疏勒县| 浙江省| 安丘市| 十堰市| 凌海市| 东乡族自治县| 五指山市| 聂拉木县| 赤壁市| 阜城县| 商丘市| 兰坪| 新巴尔虎右旗| 资中县| 正镶白旗| 凯里市| 镇赉县| 外汇| 淮阳县| 宾川县| 无锡市| 永康市| 太仓市| 孟津县| 绍兴市| 将乐县| 萍乡市| 武清区| 佛坪县| 郸城县| 德格县| 绩溪县| 澄江县| 桐城市| 千阳县| 平阳县| 浦北县| 手机| 凌源市|