MySQL - Einträge einer Tabelle zählen

So ermitteln Sie die Anzahl der Einträge einer Suchabfrage

Wer mit MySQL-Datenbankabfragen arbeitet, muss hin und wieder die Einträge einer Tabelle zählen. Vielleicht möchte man wissen, ob die betreffende Tabelle überhaupt Einträge enthält oder wie viele User das gleiche Alter haben. Für diese Problemstellung gibt es gleich mehrere Möglichkeiten.

Anzahl einer MySQL-Abfrage ermitteln

Das COUNT-Statement von MySQL zählt die Anzahl der Einträge und gibt diese entsprechend aus.

Die nachfolgende Abfrage ermittelt die Anzahl aller Benutzer der Tabelle user, deren Alter (age) größer 18 ist:


SELECT COUNT(*) FROM `users` WHERE `age` > 18 

Mit (*) werden alle Einträge gezählt. Es ist jedoch auch möglich, in den Klammern einen Spalte anzugeben, wie beispielsweise:


SELECT COUNT(id) FROM `users` WHERE `age` > 18 

Die beiden Abfragen unterscheiden sich im Grunde nicht.

Anzahl in neuer Variable speichern

Man kann jedoch auch einfach einen neuen Wert per AS-Statement schaffen, der sich ebenfalls auslesen lässt. In diesem Beispiel wird news_count als neue Zählvariable definiert:


SELECT COUNT(*) AS `news_count` FROM `news`

Auf diese Weise wurde mit der MySQL-Abfrage news_count neu erschaffen, welches jetzt den Zahlenwert der Anzahl der News-Einträge erhält und dann beispielsweise mit PHP ausgegeben werden kann.

Keine doppelten Vorkommen zählen

Darüber hinaus gibt es noch andere Fälle, in denen das COUNT-Statement sehr nützlich ist. Möchte man beispielsweise die Anzahl der verschiedenen Städte, aus denen die Benutzer kommen, zählen, dann nutzt man dafür DISTINCT, gefolgt von der gewünschten Spalte. In unserem Fall wollen wir die eindeutigen Städte von city ermitteln, ohne doppelte Einträge mitzuzählen:


SELECT COUNT(DISTINCT city) AS counter FROM users

Auf diese Weise werden über counter nur die verschiedenen Städte gezählt und nicht alle Einträge. Enthält die Datenbank-Tabelle nun insgesamt 20 Einträge aus Berlin und 5 aus München, dann sind dies dennoch lediglich zwei verschiedene Städte.

Auslesen der Anzahl mittels PHP

Eine schnelle und simple Variante, die Anzahl ohne COUNT auszulesen, bietet auch PHP mit dem Befehl mysqli_num_rows(), welcher die Anzahl der betroffenen Zeilen ermittelt und an eine Variable übergeben kann. Der Code sieht wie folgt aus:


$db_con = mysqli_connect("localhost", "bn", "pw", "db");
$query =   "SELECT id FROM news";
$res = mysqli_query($db_con, $query);
$count = mysqli_num_rows($res);

echo "Es wurden ".$count." Einträge gefunden.";

mysqli_close($db_con);

Die PHP-Variable $count enthält von mysqli_num_rows() den Wert der ausgelesenen Zeilen der Tabelle.

Diesen Tipp bewerten:

Mehr zum Thema: Webdesign aus der Kategorie Computer & Internet

Ihr Kommentar
 Ihr Name *
Keine Phantasienamen, Markennamen oder ähnliches.
 Ihr Avatar *
 E-Mail *
Wird nicht veröffentlicht. (Datenschutz)
 Kommentar *

Kommentare, die Werbung enthalten, werden nicht veröffentlicht.

Beliebt und gern gelesen:

Anwendung und Wirkung von Goji-Beeren
Erfahren Sie an dieser Stelle, wie man Goji-Beeren verzehren kann und welche Wirkungen der Wunderbeere aus China zugesprochen werden.
Bewiesene Wirkung von Arnika und ihre Verwendung in der Homöopathie
Dieser Artikel zeigt Ihnen, wie die Heilpflanze Arnika laut Homöopathie wirkt und welche Wirkungen davon tatsächlich wissenschaftlich bewiesen sind.
Wie lange sollte man den Backofen vorheizen?
Sie möchten ein Gericht im Ofen zubereiten und müssen dabei vorheizen? Wie lange ein Backofen braucht, um auf die gewünschte Temperatur zu kommen, erfahren Sie hier.
Zwiebeln ohne Tränen schneiden
Fließen beim Zwiebelschneiden ständig die Tränen? Sie glauben mit diesem Problem muss jeder Koch zurecht kommen? Weit gefehlt: Erfahren Sie, wie Sie Zwiebeln ohne Probleme klein schneiden können.
Basisches Fußbad zur Entsäuerung und Entgiftung selbst machen
Sie möchten Ihren Körper entsäuern und entgiften? Angeblich soll ein basisches Fußbad dies ermöglichen. Hier erfahren Sie, wie Sie solch ein Fußbad mit basischem Badesalz selbst machen können.