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

溫馨提示×

溫馨提示×

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

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

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

民勤县| 凤冈县| 依兰县| 潞西市| 莎车县| 慈利县| 乡宁县| 会宁县| 永昌县| 德清县| 中江县| 阿拉善盟| 锦屏县| 博乐市| 淄博市| 盐源县| 陇西县| 巴林右旗| 池州市| 利辛县| 信丰县| 南澳县| 通许县| 岳西县| 林口县| 乌鲁木齐市| 商洛市| 正安县| 休宁县| 斗六市| 麻城市| 兰西县| 江门市| 葫芦岛市| 祁连县| 衡阳市| 平山县| 德保县| 三明市| 红河县| 布尔津县|