Heim >Datenbank >MySQL-Tutorial >Was ist der Unterschied zwischen MySQL8.0 und MySQL5.7?
Unterschied: Der Index von mysql8.0 kann ausgeblendet und angezeigt werden. Er wird vom Abfrageoptimierer nicht verwendet. 3. Von mysql8 Ab 0 wird die Standardkodierung der Datenbank in utf8mb4 geändert, was alle Emoji-Zeichen umfasst.
(Empfohlenes Tutorial: MySQL-Video-Tutorial)
Der Unterschied zwischen MySQL8.0 und MySQL5.7 beträgt
MySQL bietet Nr SQL ab Version 5.7 Speicherfunktion, Dieser Teil hat in 8.0 einige Änderungen erfahren, die jedoch in der Praxis selten verwendet werden Wenn der Index ausgeblendet ist, wird er vom Abfrageoptimierer nicht verwendet. Dies bedeutet, dass Sie einen Index ausblenden und dann die Auswirkungen auf die Datenbank beobachten können. Wenn die Leistung abnimmt, bedeutet dies, dass der Index wirksam ist „Wiederherstellen“ „Anzeigen“; wenn sich die Datenbankleistung nicht ändert, bedeutet dies, dass der Index zu groß ist und gelöscht werden kann.
Die Syntax zum Ausblenden eines Index
ALTER TABLE t ALTER INDEX i INVISIBLE;
ALTER TABLE t ALTER INDEX i VISIBLE;
Wenn ein Index ausgeblendet ist, können wir aus der Ausgabezusammenfassung des Befehls show index sehen, dass der sichtbare Attributwert des Index Nein ist
**Hinweis:** Wenn der Index ausgeblendet ist, ist er Der Inhalt wird weiterhin wie ein normaler Index in Echtzeit aktualisiert. Diese Funktion selbst wird speziell zur Optimierung des Debuggens verwendet. Wenn Sie einen Index für längere Zeit ausblenden, ist es besser, ihn zu beenden, da sich die Existenz des Index auf die Einfügung auswirkt 3. Persistenz festlegen
MySQL 8 fügt einen neuen SET PERSIST-Befehl hinzu, zum Beispiel:
SET PERSIST max_connections = 500;MySQL speichert die Konfiguration dieses Befehls in der Datei mysqld-auto.cnf im Datenverzeichnis und die Datei wird als nächstes gelesen Verwenden Sie beim Start die darin enthaltene Konfiguration, um die Standardkonfigurationsdatei zu überschreiben.
4.UTF-8-Kodierung
Ab MySQL 8 wird die Standardkodierung der Datenbank in utf8mb4 geändert, das alle Emoji-Zeichen enthält. Seit vielen Jahren sind wir beim Codieren bei der Verwendung von MySQL vorsichtig, aus Angst, zu vergessen, das Standard-Latein zu ändern und Probleme mit verstümmeltem Code zu verursachen. Von nun an keine Sorgen mehr.
Komplexe Abfragen verwenden eingebettete Tabellen, zum Beispiel:
SELECT t1.*, t2.* FROM (SELECT col1 FROM table1) t1, (SELECT col2 FROM table2) t2;
WITH t1 AS (SELECT col1 FROM table1), t2 AS (SELECT col2 FROM table2) SELECT t1.*, t2.* FROM t1, t2;Auf diese Weise sieht es hierarchischer und regionaler aus. Es ist klarer und klarer zu wissen welcher Teil geändert werden soll, wenn Änderungen vorgenommen werden.
Eine der am meisten kritisierten Funktionen von MySQL ist das Fehlen der rank()-Funktion. Wenn in einer Abfrage eine Rangfolge erreicht werden muss, muss die @-Variable von Hand geschrieben werden. Aber ab 8.0 hat MySQL ein neues Konzept namens Fensterfunktion hinzugefügt, mit dem mehrere neue Abfragemethoden implementiert werden können.
Die Fensterfunktion ähnelt ein wenig einer Aggregatfunktion wie SUM() und COUNT(), führt jedoch nicht mehrzeilige Abfrageergebnisse in einer Zeile zusammen, sondern fügt die Ergebnisse wieder in mehrere Zeilen ein. Mit anderen Worten: Fensterfunktionen erfordern kein GROUP BY. Hinweis: Ein Fenster mit dem Namen w wird hier erstellt und legt fest, dass es das Feld stu_count sortiert, dann die Methode rank() für w in der Select-Klausel ausführt und das Ergebnis als Rangfeld ausgibt.
Diese Funktion ist ebenfalls eine neue Funktion von Oracle11g und spielt auch eine sehr wichtige Rolle bei der Optimierung.
Weitere Kenntnisse zum Thema Programmierung finden Sie unter:
Einführung in die Programmierung
! !
Das obige ist der detaillierte Inhalt vonWas ist der Unterschied zwischen MySQL8.0 und MySQL5.7?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!