select count() と select count(1) の違いと実行方法

select count() と select count(1) の違いと実行方法

Count(*) または Count(1) または Count([column]) は、おそらく SQL Server で最もよく使用される集計関数です。実際、多くの人はこれら 3 つを区別できません。この記事では、これら 3 つの背後にある機能、関係、原則について説明します。

過去には、パフォーマンスを向上させるために Count(*) ではなく Count(1) を使用するという、いわゆる最適化の提案をよく目にしました。その理由は、Count(*) を使用するとテーブル全体がスキャンされるからです。実際には、Count をどのように記述しても違いはありません。

Count(1) と Count(*) は、実際には Count() 内の式が NULL かどうか評価されることを意味します。NULL の場合はカウントされませんが、NULL でない場合はカウントされます。たとえば、コード 1 に示すように、Count に NULL が指定されています (オプティマイザーでは NULL を明示的に指定できないため、指定するには変数に割り当てる必要があります)。

宣言 @xx INT
SET @xx=NULL
[AdventureWorks2012].[Sales].[SalesOrderHeader] から COUNT(@xx) を選択します。

コードリスト 1. Count に NULL が指定されています。すべての行が NULL なので、結果はまったくカウントされません。当然、結果は 0 になります。

したがって、Count(*)、Count(1)、Count('anything') のいずれかを指定すると、次の図に示すように、これらの値はいずれも NULL ではないため、結果は同じになります。

Count に NULL 以外の式を指定する限り、結果は変わりません。

結果だけを見ると、 Select Count(*)Select Count(1)同じ結果を返します。

テーブルに主キーがない場合、count(1) は count(*) よりも高速です。テーブルに主キーがある場合、主キーをカウント条件として使用すると count(primary key) が最も高速になります。

テーブルにフィールドが 1 つしかない場合は、count(*) が最も高速です。

count(*) と count(1) の結果は同じで、どちらも NULL 統計が含まれますが、count(column) には NULL 統計は含まれません。

1. select 1 と select * の違い

select constant from ... すべての行に対して、常に定数という 1 つの値のみが返されます。したがって、通常は、存在するかどうかを判断するためにのみ使用されます (exists 句など)。 Select * from ... は、すべての行のすべての列を返します。

パフォーマンスの違いは、from 句と where 句によって異なります。たとえば、where 条件にインデックスを付けることができる場合、select 1 from ... の方が select * from ... よりも明らかにパフォーマンスが優れています。

2. select sum(1)の使用

select count(*)条件を満たすレコードの数を返します。これはselect sum(1)と同じです。

ただし、sum() には負の数や浮動小数点数を含む任意の数値を渡すことができ、返される値は渡された値 n * 条件を満たすレコードの数 m になります。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。

以下もご興味があるかもしれません:
  • MySQL における count(*)、count(1)、count(col) の違いのまとめ
  • Select count(*)、Count(1)、Count(column)の違いと実行方法
  • SQL Server における Select count(*) と Count(1) の違いと実行方法
  • count(1)、count(*)、count(列名)の実行の違いの詳細な説明

<<:  Windows 10 での Tomcat のインストールと展開に関する詳細なチュートリアル

>>:  Vue3+el-tableは行と列の変換を実現します

推薦する

現在使用されている設定ファイル my.cnf を表示する mysql メソッド (推奨)

my.cnfは、MySQL の起動時に読み込まれる設定ファイルです。通常は MySQL インストー...

MySQLデータを復元する2つの方法

1. はじめに少し前、開発者がテスト環境や本番環境で誤った操作をし、データベースを誤って削除/更新し...

Dockerボリューム権限管理の詳細な説明

ボリュームデータボリュームは Docker の重要な概念です。データ ボリュームは、1 つ以上のコン...

外部ネットワークアクセスを許可するためのMysql5.6の設定手順の詳細を共有する

最近、MySQL 5.6 を導入しましたが、デフォルトでは MySQL はローカル サービスのみを許...

Vue+WebSocket ページでの長時間接続のリアルタイム更新

最近、Vue プロジェクトではデータをリアルタイムで更新する必要があります。折れ線グラフは 1 秒ご...

画像の一時停止を実現するjQueryプラグイン

この記事では、画像の一時停止を実現するためのjQueryプラグインの具体的なコードを参考までに共有し...

JavaScript 関数呼び出しの典型的なサンプルコード

目次JavaScript 関数呼び出しの典型的な例JS関数の定義と呼び出し方法要約するJavaScr...

HTML テーブルタグチュートリアル (3): 幅と高さの属性 WIDTH、HEIGHT

デフォルトでは、テーブルの幅と高さはコンテンツに応じて自動的に調整されます。テーブルの幅と高さを手動...

Nginx セッション損失問題の解決策

nginx をリバース プロキシ tomcat として使用する場合、セッション損失が発生する可能性が...

MySQLのスケジュールタスクが正常に実行できない原因の分析と解決

目次序文原因分析と解決策スケジュールされたタスクを迅速に実行する要約する序文データベースのスケジュー...

ウェブページのエンコードにおける GB2312、GBK、UTF-8 の違い

まず、GB2312、GBK、UTF-8 はすべて文字エンコーディングであることを理解する必要がありま...

条件によるMysqlカウントの複数の実装方法を詳細に解説

最近、あるウェブサイトのバックエンドに一連の統計機能を追加していたのですが、条件によるカウントが必要...

docker-compose ポートと expose の違いの詳細な説明

docker-compose でコンテナ ポートを公開する方法は、ports と expose の ...

CocosCreatorでゲームコントローラーを使用する方法

目次1. シーンレイアウト2. ハンドルリスナーを追加する1. イベントの変更を監視する2. 座標設...

Linux サービスでファイアウォールを有効にする 2 つの方法

方法は2つあります: 1. サービス方法ファイアウォールのステータスを確認します。 [root@ce...