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
Freigeben: 2025-01-13 15:01:44
Original
519 Leute haben es durchsucht

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>
Nach dem Login kopieren

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

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

Das Ergebnis ist:

<code>3   2</code>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage