Heim >Datenbank >MySQL-Tutorial >COUNT(Spalte) vs. COUNT(*): Wann sollte ich Which in SQL verwenden?

COUNT(Spalte) vs. COUNT(*): Wann sollte ich Which in SQL verwenden?

Patricia Arquette
Patricia ArquetteOriginal
2025-01-13 15:01:44553Durchsuche

COUNT(column) vs. COUNT(*): When Should I Use Which in SQL?

*Detaillierte Erläuterung des Unterschieds zwischen COUNT(column) und COUNT() in SQL**

In SQL-Abfragen wird die Funktion count() zur Datenaggregation verwendet, es gibt jedoch einen subtilen, aber wichtigen Unterschied zwischen den beiden häufig verwendeten Formen count(column) und count(*).

COUNT(Spalte): NULL-Werte ausschließen

Die

count(column)-Syntax zählt die Anzahl der Nicht-NULL-Werte in der angegebenen Spalte und ignoriert effektiv Zeilen mit NULL-Spaltenwerten. Diese Funktion ist nützlich, wenn Sie die Anzahl der Nicht-Null-Werte in einer Spalte bestimmen müssen.

*COUNT(): Enthält NULL-Wert**

Im Gegensatz dazu zählt count(*) die Anzahl der Zeilen im Ergebnissatz, einschließlich Zeilen mit NULL-Werten. Im Gegensatz zu count(column) wird NULL als gültiges Zählelement behandelt. Diese Funktion ist nützlich, wenn Sie die Gesamtzahl der Zeilen ermitteln müssen, unabhängig davon, ob eine bestimmte Spalte fehlende Daten enthält.

Beispiel zur Veranschaulichung des Unterschieds

Stellen Sie sich eine Tabelle mit dem Namen #bla vor, die die folgenden Datensätze enthält:

<code class="language-sql">create table #bla(id int,id2 int)
insert #bla values(null,null)
insert #bla values(1,null)
insert #bla values(null,1)
insert #bla values(1,null)
insert #bla values(null,1)
insert #bla values(1,null)
insert #bla values(null,null)</code>

Verwenden Sie count(column), um die folgende Abfrage auszuführen:

<code class="language-sql">select count(id),count(id2)
from #bla</code>

Das Ergebnis ist:

<code>3   2</code>

Davon zählt count(id) nur drei Nicht-NULL-Werte in der Spalte id, während count(id2) zwei Nicht-NULL-Werte in der Spalte id2 zählt.

Das Ersetzen von count(*) durch count(column) führt jedoch zu 7, wie in der folgenden Abfrage gezeigt:

<code class="language-sql">select count(*)
from #bla</code>

In diesem Fall enthält count(*) sieben Zeilen aus der Tabelle, unabhängig davon, ob sie NULL-Werte enthalten. Diese Unterscheidung zwischen dem Zählen von Nicht-NULL-Werten und dem Zählen von Zeilen wird besonders wichtig, wenn es um Datensätze geht, die fehlende Daten enthalten.

Das obige ist der detaillierte Inhalt vonCOUNT(Spalte) vs. COUNT(*): Wann sollte ich Which in SQL verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn