ホームページ >データベース >mysql チュートリアル >MySQL WHERE 句の条件の順序はクエリのパフォーマンスに影響しますか?
MySQL WHERE 句の一連の条件はパフォーマンスに影響しますか?
広範な WHERE 句と多数の条件を含む MySQL クエリでは、これは非常に重要ですパフォーマンスを最適化します。企業 ID などの 1 つの特定の条件により、検索スペースが数十万から数十に大幅に減少するとします。この条件は句の最初に配置する必要がありますか?
特定のパラメータに一致するクライアントを検索するクエリの 2 つのバージョンを考えてみましょう:
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 のパフォーマンスに最小限の影響を与えるか、まったく影響しないと考えられていました。しかし、最近のテストと洞察により、特定のシナリオでは実際に違いが生じる可能性があることが明らかになりました。
短絡と条件の順序
重要な要素は短いです-回路。 MySQL では、AND または OR で接続された複合条件を評価する場合、データベース エンジンは、条件が関連する場合にのみ最初のオペランドを評価する場合があります。最初の条件によって検索スペースが大幅に絞り込まれる場合、この最適化により時間を大幅に節約できます。
デモ
この効果を説明するために、次のクエリを考えてみましょう。
-- query #1 SELECT myint FROM mytable WHERE myint >= 3 OR myslowfunction('query #1', myint) = 1; -- query #2 SELECT myint FROM mytable WHERE myslowfunction('query #2', myint) = 1 OR myint >= 3;
唯一の違いは、OR 条件のオペランドの順序です。 myslowfunction は、各呼び出しのログを記録する副作用を含む、意図的に高価な関数です。
これらのクエリが実行されるとき:
myslowfunction called for query #1 with value 1 myslowfunction called for query #1 with value 2 myslowfunction called for query #2 with value 1 myslowfunction called for query #2 with value 2 myslowfunction called for query #2 with value 3 myslowfunction called for query #2 with value 4
トレースに見られるように、myslowfunction はクエリに対して呼び出される回数が少なくなります。 #1 は、最初の条件 (myint >= 3) により、それを満たさない多くの行が削除されるためです。この条件を最初に指定すると、早期終了が可能になり、slow 関数の不必要な評価が防止されます。
結論
したがって、質問に対する答えは次のとおりです。はい、 WHERE 句内の条件の順序は、ショートサーキット により MySQL のパフォーマンスに影響を与える場合があります。最初に制限条件を設定することで、データベース エンジンは不必要な処理を回避し、効率を最大化することでクエリの実行を最適化できます。
以上がMySQL WHERE 句の条件の順序はクエリのパフォーマンスに影響しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。