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

溫馨提示×

溫馨提示×

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

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

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

修武县| 伊金霍洛旗| 卓资县| 北海市| 宁武县| 德化县| 衡山县| 白水县| 昌吉市| 安康市| 潞西市| 广水市| 平舆县| 延津县| 常宁市| 兴城市| 基隆市| 大悟县| 南宫市| 翁源县| 平阳县| 呼图壁县| 三台县| 太和县| 古浪县| 凤阳县| 略阳县| 高邑县| 方正县| 郴州市| 通海县| 贵阳市| 壤塘县| 乌兰县| 稻城县| 黎平县| 汤阴县| 海盐县| 五台县| 威宁| 团风县|