中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

开封市| 扶风县| 梨树县| 汉中市| 卢龙县| 汾阳市| 嘉兴市| 平原县| 安泽县| 久治县| 资溪县| 正阳县| 大竹县| 马关县| 衡阳市| 甘德县| 银川市| 长阳| 若尔盖县| 宣汉县| 探索| 万安县| 梧州市| 当雄县| 洪湖市| 确山县| 衡水市| 太湖县| 厦门市| 阜阳市| 齐齐哈尔市| 左云县| 德格县| 宁波市| 洛浦县| 资中县| 集安市| 陆河县| 凉城县| 社旗县| 江油市|