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」是一個故意延遲一秒鐘的函數。查詢執行顯示:
這表明,當一個慢速函數出現當OR 條件的左側且其操作數並不總是為真時,該函數的執行頻率會更高。
結論:
總之,WHERE 子句中的條件順序會影響 MySQL 效能,因為短路。為了優化效能,請儘早將預計會顯著減少檢查行數的條件(例如公司 ID)放入條件鏈中。
以上是WHERE 子句條件排序如何影響 MySQL 查詢效能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!