您好,登錄后才能下訂單哦!
本篇內容介紹了“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優化案例教程”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。