MySQL WHERE 句の条件の順序とパフォーマンス
多数の条件を含む複雑なデータベース クエリを作成する場合、それらの条件の順序が影響を与える可能性があります。 MySQLのパフォーマンス。一般的なシナリオには、広範かつ限定的な条件の組み合わせが含まれます。質問が生じます: 制限条件が WHERE 句の最初に現れるか最後に現れるかは重要ですか?
答えは必ずしも単純ではありません。特定の状況では、この順序は短絡動作によりパフォーマンスに影響を与える可能性があります。次のクエリを考えてみましょう:
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
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 が大量の行を検索する可能性があります。 2 番目のクエリでは、会社の条件が最初に評価され、処理する必要がある行数を大幅に減らすことができます。
この最適化は、MySQL が WHERE 句の評価で短絡ロジックを使用するために発生します。特定の行で会社の条件が失敗した場合、MySQL はその行の残りの条件の評価を続行しません。
ただし、特に制限条件が適用されている場合、このパフォーマンス上の利点は必ずしも重要であるとは限らないことに注意することが重要です。選択性は高くありません (つまり、多数の行が削除されません)。
したがって、WHERE 句内の条件の順序が MySQL に影響を与える可能性があります。パフォーマンスに影響を与えるため、すべてのケースに適用できる一般的なルールではありません。特定のクエリに対してパフォーマンス テストを実施し、条件を並べ替えることで目立った改善が得られるかどうかを判断することをお勧めします。
以上がMySQL WHERE 句の条件の順序はクエリのパフォーマンスに影響しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。