Zusammenfassung der Nutzungsunterschiede der MySQL Count-Funktion
Vorwort
Hallo zusammen, wie viel weißt du über Count in MySQL?
Der Bedarf an statistischen Daten ist in unserer täglichen Entwicklung sehr leicht zu erkennen. MySQL unterstützt auch eine Vielzahl von Berechnungsfunktionen,
Lassen Sie uns Machen Sie es als nächstes. Schauen Sie sich die Unterschiede zwischen ihnen an und ob sie irgendwelche Fallstricke haben. [Empfohlenes Lernen: MySQL-Video-Tutorial]
Der Unterschied zwischen count(*), count(1), count(id)
Die Bedeutung von count: count() ist eine Aggregatfunktion für die zurückgegebene Ergebnisse Festlegen, Zeile für Zeile beurteilen. Wenn der Parameter der Zählfunktion nicht NULL ist, wird der kumulative Wert um 1 erhöht, andernfalls wird er nicht hinzugefügt. Abschließend wird der kumulative Wert zurückgegeben.
count (Feld) ist etwas Besonderes. Es bedeutet, dass die Gesamtzahl der Datenzeilen zurückgegeben wird, die die Bedingungen erfüllen, und der Parameter „Feld“ nicht NULL ist wird geben, was es will Was;
InnoDB gibt nur notwendige Werte;
- Der aktuelle Optimierer optimiert nur die Semantik von count(*), um „die Anzahl der Zeilen zu ermitteln“, und andere „offensichtliche“ Optimierungen tun dies nicht fertig
- Beispiel:
count (Primärschlüssel-ID), die InnoDB-Engine durchläuft die gesamte Tabelle, entnimmt den ID-Wert jeder Zeile und gibt ihn an die Serverebene zurück. Nachdem die Serverschicht die ID erhalten hat, beurteilt sie, dass sie nicht leer sein darf, und sammelt sie daher Zeile für Zeile. Für
count(1) durchläuft die InnoDB-Engine die gesamte Tabelle, ruft jedoch nicht den Wert ab. Die Serverschicht fügt in jede zurückgegebene Zeile eine Zahl „1“ ein. Wenn festgestellt wird, dass sie nicht leer sein darf, wird sie zeilenweise akkumuliert. count (Feld): Wenn der Server ein Feld benötigt, gibt er das Feld zurück. Wenn das Feld leer ist, wird die Statistik nicht ausgeführt. Wenn der Wert des Feldes zu groß ist, führt dies zu Ineffizienz.
count(字段)<count(主键 id)<count(1)≈count(*)
Der Optimierer erledigt seine Aufgabe und findet die kleinste zu durchlaufende Zahl. InnoDB ist eine indexorganisierte Tabelle. Die Blattknoten des Primärschlüssel-Indexbaums sind Daten, während die Blattknoten des gewöhnlichen Indexbaums die Primärschlüsselwerte sind. Daher ist der gewöhnliche Indexbaum viel kleiner als der Primärschlüssel-Indexbaum. Bei Operationen wie count(*) sind die beim Durchlaufen eines beliebigen Indexbaums erhaltenen Ergebnisse logisch dieselben. Daher findet der MySQL-Optimierer den kleinsten zu durchquerenden Baum. Um sicherzustellen, dass die Logik korrekt ist, ist die Minimierung der gescannten Datenmenge eine der allgemeinen Regeln beim Entwurf von Datenbanksystemen.
// 数据中存在null值数据 select count(*) from audit_log a; 结果:1 select count(id) from audit_log a; 结果:0
Wir sehen, dass die Ergebnisse von count inkonsistent sein sollten, aber count(id) ist gleich 0
Das liegt daran, dass count(field) zählt nicht, das Feld Der Wert ist null
Wenn das Feld also ein nicht leeres Feld ist, muss count(*) verwendet werden, um dieses Problem zu lösen.
count(*)-ZusammenfassungMyISAM-Tabelle ist zwar schnell, unterstützt jedoch keine Transaktionen;
show table status command kehrt schnell zurück, ist aber nicht genau;
- Die direkte Zählung der InnoDB-Tabelle (*) durchläuft die gesamte Tabelle. Das Ergebnis ist zwar korrekt, führt jedoch zu Leistungsproblemen.
Das obige ist der detaillierte Inhalt vonZusammenfassung der Nutzungsunterschiede der MySQL Count-Funktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



MySQL ist für Anfänger geeignet, da es einfach zu installieren, leistungsfähig und einfach zu verwalten ist. 1. Einfache Installation und Konfiguration, geeignet für eine Vielzahl von Betriebssystemen. 2. Unterstützung grundlegender Vorgänge wie Erstellen von Datenbanken und Tabellen, Einfügen, Abfragen, Aktualisieren und Löschen von Daten. 3. Bereitstellung fortgeschrittener Funktionen wie Join Operations und Unterabfragen. 4. Die Leistung kann durch Indexierung, Abfrageoptimierung und Tabellenpartitionierung verbessert werden. 5. Backup-, Wiederherstellungs- und Sicherheitsmaßnahmen unterstützen, um die Datensicherheit und -konsistenz zu gewährleisten.

Navicat selbst speichert das Datenbankkennwort nicht und kann das verschlüsselte Passwort nur abrufen. Lösung: 1. Überprüfen Sie den Passwort -Manager. 2. Überprüfen Sie Navicats "Messnot Password" -Funktion; 3.. Setzen Sie das Datenbankkennwort zurück; 4. Kontaktieren Sie den Datenbankadministrator.

Erstellen Sie eine Datenbank mit Navicat Premium: Stellen Sie eine Verbindung zum Datenbankserver her und geben Sie die Verbindungsparameter ein. Klicken Sie mit der rechten Maustaste auf den Server und wählen Sie Datenbank erstellen. Geben Sie den Namen der neuen Datenbank und den angegebenen Zeichensatz und die angegebene Kollektion ein. Stellen Sie eine Verbindung zur neuen Datenbank her und erstellen Sie die Tabelle im Objektbrowser. Klicken Sie mit der rechten Maustaste auf die Tabelle und wählen Sie Daten einfügen, um die Daten einzufügen.

MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

MySQL und SQL sind wesentliche Fähigkeiten für Entwickler. 1.MYSQL ist ein Open -Source -Relational Database Management -System, und SQL ist die Standardsprache, die zum Verwalten und Betrieb von Datenbanken verwendet wird. 2.MYSQL unterstützt mehrere Speichermotoren durch effiziente Datenspeicher- und Abruffunktionen, und SQL vervollständigt komplexe Datenoperationen durch einfache Aussagen. 3. Beispiele für die Nutzung sind grundlegende Abfragen und fortgeschrittene Abfragen wie Filterung und Sortierung nach Zustand. 4. Häufige Fehler umfassen Syntaxfehler und Leistungsprobleme, die durch Überprüfung von SQL -Anweisungen und Verwendung von Erklärungsbefehlen optimiert werden können. 5. Leistungsoptimierungstechniken umfassen die Verwendung von Indizes, die Vermeidung vollständiger Tabellenscanning, Optimierung von Join -Operationen und Verbesserung der Code -Lesbarkeit.

Sie können eine neue MySQL -Verbindung in Navicat erstellen, indem Sie den Schritten folgen: Öffnen Sie die Anwendung und wählen Sie eine neue Verbindung (Strg N). Wählen Sie "MySQL" als Verbindungstyp. Geben Sie die Hostname/IP -Adresse, den Port, den Benutzernamen und das Passwort ein. (Optional) Konfigurieren Sie erweiterte Optionen. Speichern Sie die Verbindung und geben Sie den Verbindungsnamen ein.

Sie können PhpMyAdmin in den folgenden Schritten öffnen: 1. Melden Sie sich beim Website -Bedienfeld an; 2. Finden und klicken Sie auf das Symbol phpmyadmin. 3. Geben Sie MySQL -Anmeldeinformationen ein; 4. Klicken Sie auf "Login".

Schritte zur Durchführung von SQL in Navicat: Verbindung zur Datenbank herstellen. Erstellen Sie ein SQL -Editorfenster. Schreiben Sie SQL -Abfragen oder Skripte. Klicken Sie auf die Schaltfläche Ausführen, um eine Abfrage oder ein Skript auszuführen. Zeigen Sie die Ergebnisse an (wenn die Abfrage ausgeführt wird).
