SQL Count(*) のパフォーマンスへの影響
COUNT(*) オペレーションを含むクエリは、特定の基準に基づいて実行時間に大きな違いを示す可能性がありますクエリで使用されます。たとえば、ここで示したケースでは、単純な COUNT(*) だけを実行すると、カウントを 0、1、または 1 より大きく比較する同じクエリよりもはるかに高速に実行されます。
この矛盾は、SQL によるこれらのクエリの最適化方法に起因します。 。最初のクエリでは、SQL は「exists」として知られる最適化を採用し、すべての行をカウントするのではなく、テーブル内の行の存在をチェックします。これにより、実行時間が大幅に短縮されます。
対照的に、他の 2 つのクエリでは、SQL は非クラスター化インデックスを利用してカウント操作を効率的に実行します。ただし、テーブルにはそのようなインデックスがないため、SQL はカウントを取得するためにテーブル全体をスキャンすることを強制され、パフォーマンスに重大な影響を及ぼします。
Count(*) のパフォーマンスの向上
この状況で COUNT(*) クエリのパフォーマンスを向上させるには、いくつかの手法を使用できます。採用:
以上がSQL のパフォーマンスを向上させるために COUNT(*) クエリを最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。