首頁 >資料庫 >mysql教程 >WHERE 子句條件排序如何影響 MySQL 查詢效能?

WHERE 子句條件排序如何影響 MySQL 查詢效能?

Patricia Arquette
Patricia Arquette原創
2024-12-29 12:31:14885瀏覽

How Does WHERE Clause Condition Ordering Affect MySQL Query Performance?

WHERE 子句條件排序對MySQL 效能的影響

當使用多個條件建構複雜性查詢時,這些條件的複雜順序可能會影響MySQL 的效能。特定條件(例如按公司 ID 過濾)可以顯著減少檢查的行數。

問題:

考慮以下兩個不同條件排序的查詢:

查詢1:

SELECT * FROM clients WHERE 
       (firstname LIKE :foo OR lastname LIKE :foo OR phone LIKE :foo) AND 
       (firstname LIKE :bar OR lastname LIKE :bar OR phone LIKE :bar) AND 
       company = :ugh

查詢2:

 SELECT * FROM clients WHERE 
       company = :ugh AND
       (firstname LIKE :foo OR lastname LIKE :foo OR phone LIKE :foo) AND 
       (firstname LIKE :bar OR lastname LIKE :bar OR phone LIKE :bar) 

這些條件的順序會影響MySQL的效率嗎?

答案:

WHERE子句條件的順序確實會影響MySQL在特定情況下的效能。請考慮以下範例:

查詢3:

SELECT myint FROM mytable WHERE myint >= 3 OR myslowfunction('query #1', myint) = 1;

查詢4:

SELECT myint FROM mytable WHERE myslowfunction('query #2', myint) = 1 OR myint >= 3;

這些查詢之間的唯一差異是OR 條件中運算元的順序。 「myslowfunction」是一個故意延遲一秒鐘的函數。查詢執行顯示:

  • 查詢 3:myslowfunction 被呼叫四次(myint 值 1、2、3、4)。
  • 查詢4:myslowfunction 被呼叫七次( myint 值1、2、3、4、5、6、 7).

這表明,當一個慢速函數出現當OR 條件的左側且其操作數並不總是為真時,該函數的執行頻率會更高。

結論:

總之,WHERE 子句中的條件順序會影響 MySQL 效能,因為短路。為了優化效能,請儘早將預計會顯著減少檢查行數的條件(例如公司 ID)放入條件鏈中。

以上是WHERE 子句條件排序如何影響 MySQL 查詢效能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn