Heim >Datenbank >MySQL-Tutorial >So zählen Sie Abfrageergebnisse in MySQL

So zählen Sie Abfrageergebnisse in MySQL

青灯夜游
青灯夜游Original
2022-06-20 19:11:237519Durchsuche

Statistische Methode: 1. Verwenden Sie „COUNT(*)“, um alle Abfrageergebnisse zu zählen, und die Syntax lautet „SELECT COUNT(*) FROM table name;“. 2. Verwenden Sie „COUNT (Feldname)“, um Nicht-NULL-Ergebnisse zu zählen. Die Syntax lautet „SELECT COUNT (Spaltenname)“ FROM Tabellenname;“. 3. Verwenden Sie „COUNT (DISTINCT Feldname)“, um Nicht-NULL-Ergebnisse zu zählen Ergebnisse ohne Duplizierung, Syntax „SELECT COUNT(DISTINCT Spaltenname)“ FROM Tabellenname;“.

So zählen Sie Abfrageergebnisse in MySQL

Die Betriebsumgebung dieses Tutorials: Windows7-System, MySQL8-Version, Dell G3-Computer.

In MySQL können Sie die Funktion COUNT() verwenden, um Abfrageergebnisse zu zählen.

MySQL COUNT()-Funktion

COUNT()-Funktion zählt die Gesamtzahl der in der Datentabelle enthaltenen Datensatzzeilen oder gibt die Anzahl der in der Spalte enthaltenen Datenzeilen basierend auf den Abfrageergebnissen zurück

Die Rückgabe Der Typ der COUNT()-Funktion ist BIGINT. Wenn keine passende Zeile gefunden wird, gibt die Funktion COUNT() 0 zurück. Die Funktion

COUNT() hat drei Syntaxen:

COUNT(*)
COUNT(字段名)
COUNT(DISTINCT 字段名)

COUNT(*)

COUNT(*)Die Funktion gibt die Anzahl der Zeilen in der Ergebnismenge zurück, die von der SELECT-Anweisung zurückgegeben wird. Die Funktion COUNT(*) zählt Zeilen, die NULL- und Nicht-NULL-Werte enthalten, also alle Zeilen. COUNT(*)函数返回由SELECT语句返回的结果集中的行数。COUNT(*)函数计算包含NULL和非NULL值的行,即:所有行。

如果使用COUNT(*)函数对表中的数字行进行计数,而不使用WHERE子句选择其他列,则其执行速度非常快。

这种优化仅适用于MyISAM表,因为MyISAM表的行数存储在information_schema数据库的tables表的table_rows列中; 因此,MySQL可以很快地检索它。

COUNT(列名)

COUNT(字段名)返回不包含NULL值的行数。

COUNT(DISTINCT 列名)

COUNT(DISTINCT 字段名)

Wenn Sie die Funktion COUNT(*) verwenden, um numerische Zeilen in einer Tabelle zu zählen, ohne eine WHERE-Klausel zur Auswahl anderer Spalten zu verwenden, ist die Leistung sehr schnell.
  • Diese Optimierung funktioniert nur für MyISAM-Tabellen, da die Zeilenanzahl einer MyISAM-Tabelle in der Spalte „table_rows“ der Tabelle „tables“ der Datenbank „information_schema“ gespeichert wird. Daher kann MySQL sie sehr schnell abrufen.

  • COUNT(Spaltenname)

COUNT(Feldname)Gibt die Anzahl der Zeilen zurück, die keine NULL-Werte enthalten. COUNT(DISTINCT-Spaltenname)

  • COUNT(DISTINCT-Feldname)Gibt die Anzahl der eindeutigen Zeilen zurück, die keine NULL-Werte enthalten.

DISTINCT-Operator ermöglicht die Berechnung unterschiedlicher Werte im Ergebnis, d. h. Deduplizierung.

So zählen Sie Abfrageergebnisse in MySQL

So zählen Sie Abfrageergebnisse in MySQL

MySQL COUNT-Beispiel

So zählen Sie Abfrageergebnisse in MySQL

  • Erstellen Sie eine neue Tabelle mit dem Namen „demo“ und fügen Sie einige Beispieldaten ein

So zählen Sie Abfrageergebnisse in MySQL

Demos-Tabelle für alle Zeilen berechnen Verwenden Sie in die Funktion COUNT(*)

-- create a demos table
CREATE TABLE IF NOT EXISTS demos(
 id int auto_increment primary key,
 val int 
);
So zählen Sie Abfrageergebnisse in MySQL

Sie können eine WHERE-Klausel hinzufügen, um eine Zählbedingung anzugeben. Um beispielsweise nur Zeilen zu zählen, in denen die Spalte „val“ einen Wert gleich 2 enthält, verwenden Sie die Folgende Abfrage:
    -- insert some sample data
    INSERT INTO demos(val)
    VALUES(1),(1),(2),(2),(NULL),(3),(4),(NULL),(5);
  • Zwei NULL-Werte in der Val-Spalte werden ignoriert.

So zählen Sie Abfrageergebnisse in MySQL

Um eindeutige Zeilen in der Demotabelle zu zählen, können Sie den DISTINCT-Operator wie folgt zur COUNT-Funktion hinzufügen:

-- select data from demos table
SELECT * FROM demos;

🎜Ignorieren Sie die beiden doppelten Werte 1, 2 und zwei in der Zählung NULL Wert. 🎜🎜【Verwandte Empfehlung: 🎜MySQL-Video-Tutorial🎜】🎜

Das obige ist der detaillierte Inhalt vonSo zählen Sie Abfrageergebnisse in MySQL. 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