MySQL ist ein Open-Source-Datenbankverwaltungssystem, das in verschiedenen Websites, Data Warehouses und Unternehmensanwendungen weit verbreitet ist. In MySQL bezieht sich das Kodierungsformat auf die interne binäre Speichermethode für in der Datenbank gespeicherte Textinhalte.
Wenn Ihre Datenbank Sonderzeichen wie chinesische oder andere nicht-englische Zeichen speichert, müssen Sie das richtige Codierungsformat festlegen, um sicherzustellen, dass diese Zeichen korrekt gespeichert und abgerufen werden können. In diesem Artikel wird erläutert, wie Sie das Codierungsformat der MySQL-Datenbank ändern.
Schritt 1: Sichern Sie die Datenbank
Bevor Sie Datenbankänderungen vornehmen, sichern Sie unbedingt die Datenbank, um Datenverlust oder nicht behebbare Schäden zu verhindern. Sie können das von MySQL bereitgestellte Tool mysqldump verwenden, um die Datenbank zu sichern. Der Befehl lautet wie folgt:
mysqldump -u [username] -p [database_name] > backup.sql
Unter anderem ist [Benutzername] der Benutzername der Datenbank, [Datenbankname] ist der Name der zu sichernden Datenbank bedeutet >, dass der Sicherungsinhalt in die Datei „backup.sql“ wiederhergestellt wird.
Schritt 2: Datenbankkodierung anzeigen
Um die Standardkodierung in der aktuellen MySQL-Datenbank anzuzeigen, können Sie den folgenden Befehl ausführen:
SELECT @@character_set_database;
Dieser Befehl zeigt das aktuelle Standardkodierungsformat der Datenbank an.
Schritt 3: Datenbankkodierung ändern
Um die Datenbankkodierung zu ändern, müssen Sie die folgenden Schritte ausführen:
find / -name my.cnf
[client] default-character-set=utf8mb4 [mysql] default-character-set=utf8mb4 [mysqld] collation-server = utf8mb4_unicode_ci character-set-server = utf8mb4
sudo service mysql restart
SELECT @@character_set_database;
Führen Sie den folgenden Befehl aus, um eine SQL-Anweisung für alle Tabellen zu generieren, die aktualisiert werden müssen:
SELECT CONCAT('ALTER TABLE `', table_schema, '`.`', table_name, '` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;') AS execute_sql FROM information_schema.tables WHERE table_schema = '[database_name]' AND table_type = 'BASE TABLE' ORDER BY table_name DESC;
Kopieren Sie die Ergebnisse in ein Terminal und führen Sie sie aus, um alle Tabellen in die neue Kodierung zu konvertieren. Wie unten gezeigt:
ALTER TABLE `table1` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ALTER TABLE `table2` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ...
SHOW FULL COLUMNS FROM [table_name];
Das obige ist der detaillierte Inhalt vonÄndern Sie die MySQL-Datenbankkodierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!