Heim > Datenbank > MySQL-Tutorial > COUNT(Spalte) vs. COUNT(*): Was ist der Unterschied in SQL?

COUNT(Spalte) vs. COUNT(*): Was ist der Unterschied in SQL?

Linda Hamilton
Freigeben: 2025-01-13 14:52:42
Original
902 Leute haben es durchsucht

COUNT(column) vs. COUNT(*): What's the Difference in SQL?

Der Unterschied zwischen COUNT(Spalte) und COUNT(*) in SQL

Frage

Was ist der Unterschied zwischen COUNT(Spalte) und COUNT(*) beim Abfragen von SQL-Tabellen?

Erklärung

COUNT(column) zählt die Anzahl der Nicht-Null-Werte in der angegebenen Spalte. Im Gegensatz dazu zählt COUNT(*) alle Zeilen in einer Tabelle, unabhängig davon, ob die angegebene Spalte Nullwerte enthält.

Beispiel

Betrachten Sie das folgende Formular:

id name
1 John Doe
2 Jane Doe
3 NULL
4 NULL

Vergleich von COUNT(name) und COUNT(*)

  • COUNT(name): Schließt Zeilen mit NULL-Werten aus, was zu 2 führt.
  • COUNT(*): Enthält Zeilen mit NULL-Werten, was 4 ergibt.

NULL-Wert-Behandlung

COUNT(Spalte) ignoriert NULL-Werte, während COUNT(*) sie als gültige Einträge behandelt. Dieses Verhalten kann sich auf Abfrageergebnisse auswirken, insbesondere wenn Bedingungen auf die WHERE-Klausel angewendet werden.

Zusätzliche Informationen

Bedenken Sie die folgende Abfrage:

<code class="language-sql">SELECT name, COUNT(*)
FROM table
GROUP BY name
HAVING COUNT(*) > 2;</code>
Nach dem Login kopieren
  • Bei Verwendung von COUNT(*) enthält das Ergebnis eine Zeile mit NULL-Werten und eine Anzahl von NULL-Werten.
  • Mit COUNT(name) werden NULL-Werte ausgeschlossen, sodass die Zeile nicht im Ergebnis zurückgegeben wird.

Das obige ist der detaillierte Inhalt vonCOUNT(Spalte) vs. COUNT(*): Was ist der Unterschied in SQL?. 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