結合基準と Where 句フィルターのどちらの SQL クエリが速いですか?
元の質問:
結合基準でフィルタリングするか、WHERE でフィルタリングするか、どちらのアプローチがより効率的ですか?句?
パフォーマンス分析:
一般的な考えに反して、テストの結果、WHERE 句フィルタが結合基準フィルタよりわずかに高速であることが判明しました。ただし、パフォーマンスの違いはわずかです。
クエリ実行プラン:
どちらのクエリ構造も、同じフィルター処理された結果セットを生成するため、結果は同じ実行プランになります。
論理的一貫性:
論理的な観点からは、INNER JOIN が LEFT JOIN に置き換えられても意味をなすため、フィルタを WHERE 句に適用することが望ましいです:
SELECT * FROM TableA a LEFT JOIN TableXRef x ON x.TableAID = a.ID LEFT JOIN TableB b ON x.TableBID = b.ID WHERE a.id = 1
このクエリは、JOIN タイプに関係なく、a.id が 1 であるレコードのみを返します。したがって、遅延評価が必要なシナリオでは、WHERE 句フィルターの方が論理的に一貫性があります。
結論:
一方、WHERE 句を使用するとパフォーマンスが若干向上します。フィルターを使用する場合、2 つのアプローチのどちらを選択するかについては、主に論理的な一貫性とコードの可読性を考慮する必要があります。
以上がJOIN 基準と WHERE 句のフィルタリング: どちらの SQL クエリのパフォーマンスが優れているか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。