*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
Diecount(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!