亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

MySQL中NOT EXISTS優化案例教程

發布時間:2021-11-10 14:08:31 來源:億速云 閱讀:564 作者:iii 欄目:MySQL數據庫

本篇內容介紹了“MySQL中NOT EXISTS優化案例教程”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一、原始語句:

SELECT * FROM dcf_account.t_posting_transaction t1 WHERE NOT EXISTS ( SELECT * FROM dcf_loan.t_account_posting_detail t2 WHERE t1.track_no = t2.posting_num
     );

二、關于優化改語句的幾點思考:
    對于原始語句,因為是NOT EXISTS判斷,所以子查詢中沒有必要SELECT 只需SELECT ID甚至是SELECT 1都可以。另外,鑒于MySQL子查詢算法性能較差,考慮改寫成對應的JOIN方式,因為這里是NOT EXIST判斷,所以改寫時有一定技巧,即可使用左連接,然后過濾出未能成功連接的記錄。還有,原始語句最外層的查詢也是SELECT 至于這個是否有必要應當依據具體業務,盡量在滿足業務要求的條件下取盡可能少的字段。最后,即時做了上述優化,若在連接條件上沒有合適的索引SQL性能仍然會非常差(特別是在表的數據量巨大的時候),所以考慮在連接的條件列t1.track_no 和 t2.posting_num上分別創建索引。

三、最終的優化結果如下
    語句由原來的進一個小時的運行時間減少到1秒內。

SELECT t1.id FROM dcf_account.t_posting_transaction t1 LEFT JOIN dcf_loan.t_account_posting_detail t2 ON t1.track_no = t2.posting_num WHERE t2.id IS NULL;

“MySQL中NOT EXISTS優化案例教程”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

和龙市| 巴彦县| 金沙县| 潜江市| 哈密市| 敖汉旗| 庆云县| 大足县| 潼南县| 桃江县| 四川省| 淮北市| 右玉县| 双桥区| 新泰市| 平罗县| 青阳县| 大厂| 信阳市| 合阳县| 古田县| 田阳县| 常山县| 黄陵县| 扬州市| 夏邑县| 桂东县| 高州市| 武功县| 岑溪市| 阳春市| 河南省| 武强县| 融水| 留坝县| 通江县| 周口市| 新巴尔虎左旗| 武隆县| 富裕县| 九寨沟县|