Maison  >  Article  >  base de données  >  Comment modifier l'encodage des caractères dans MySQL

Comment modifier l'encodage des caractères dans MySQL

PHPz
PHPzoriginal
2023-04-17 16:45:044118parcourir

MySQL est un système de gestion de bases de données relationnelles populaire. Lors de la création de bases de données et de tables, nous définissons généralement des jeux de caractères et des encodages de caractères. Si le codage des caractères de la base de données et de la table est incohérent, une partie ou la totalité des données peut être perdue. Il est donc très important de définir correctement le codage des caractères. Dans cet article, je vais vous expliquer comment modifier le codage des caractères d'une base de données ou d'une table existante dans MySQL.

Afficher le codage des caractères dans MySQL

Avant de modifier le codage des caractères, nous devons d'abord comprendre le codage des caractères utilisé par la base de données ou la table actuelle. Il peut être visualisé via l'instruction SQL suivante :

SHOW CREATE DATABASE database_name;
SHOW CREATE TABLE table_name;

Parmi eux, database_name et table_name représentent respectivement les noms de base de données et de table à afficher. Après avoir exécuté la commande ci-dessus, vous pouvez voir les informations de codage des caractères dans les résultats. database_nametable_name 分别表示要查看的数据库和表名。执行以上命令后,可以在结果中看到字符编码信息。

修改数据库字符编码

一般情况下,我们不需要修改数据库的字符编码。如果确实需要修改,可以按照以下步骤进行操作:

  1. 停止 MySQL 服务。
sudo systemctl stop mysql
  1. 备份原始数据和数据库定义文件。
mysqldump -u root -p --opt --default-character-set=utf8mb4 dbname > dbname_backup.sql
cp -a /var/lib/mysql /var/lib/mysql_backup

其中,dbname 表示要备份的数据库名。

  1. 修改 MySQL 配置文件 /etc/mysql/my.cnf

[mysqld] 区块下添加以下内容:

[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

如果已经存在相应的配置项,则直接修改其对应的值即可。使用 utf8mb4 字符集和 utf8mb4_unicode_ci 排序规则可以支持更多语言的字符。

  1. 启动 MySQL 服务,并修改数据库字符编码。
sudo systemctl start mysql
mysql -u root -p
ALTER DATABASE dbname CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

其中,dbname 表示要修改字符编码的数据库名。

修改表字符编码

如果想要修改表的字符编码和排序规则,可以按照以下步骤进行操作:

  1. 备份原始数据和表定义文件。
mysqldump -u root -p --opt --default-character-set=utf8mb4 dbname tablename > tablename_backup.sql

其中,dbnametablename 分别表示要备份的数据库和表名。

  1. 修改表字符编码和排序规则。
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

其中,table_name 表示要修改字符编码的表名。

执行以上命令后,MySQL 会将表的所有字符类型字段的编码和排序规则更改为 utf8mb4utf8mb4_unicode_ci

修改字段字符编码

如果只想修改表中某个字段的字符编码,可以按照以下步骤进行操作:

  1. 备份数据。
mysqldump -u root -p --opt --default-character-set=utf8mb4 dbname tablename > tablename_backup.sql

其中,dbnametablename 分别表示要备份的数据库和表名。

  1. 修改字段字符编码。
ALTER TABLE tablename MODIFY COLUMN column_name varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

其中,tablenamecolumn_name 分别表示要修改字符编码的表和字段名。

执行以上命令后,MySQL 会将该字段的字符编码和排序规则更改为 utf8mb4utf8mb4_unicode_ci

Modifier le codage des caractères de la base de données

Dans des circonstances normales, nous n'avons pas besoin de modifier le codage des caractères de la base de données. Si vous avez vraiment besoin de le modifier, vous pouvez suivre les étapes ci-dessous :

  1. Arrêtez le service MySQL.
rrreee
  1. Sauvegardez les données d'origine et les fichiers de définition de base de données.
rrreeeParmi eux, dbname représente le nom de la base de données à sauvegarder. 🎜
  1. Modifiez le fichier de configuration MySQL /etc/mysql/my.cnf.
🎜Ajoutez le contenu suivant sous le bloc [mysqld] : 🎜rrreee🎜Si l'élément de configuration correspondant existe déjà, modifiez simplement sa valeur correspondante directement. Les caractères d'un plus grand nombre de langues peuvent être pris en charge à l'aide du jeu de caractères utf8mb4 et du classement utf8mb4_unicode_ci. 🎜
  1. Démarrez le service MySQL et modifiez l'encodage des caractères de la base de données.
rrreee🎜Parmi eux, dbname représente le nom de la base de données dont l'encodage des caractères doit être modifié. 🎜🎜Modifier l'encodage des caractères du tableau🎜🎜Si vous souhaitez modifier l'encodage des caractères et les règles de tri du tableau, vous pouvez suivre les étapes ci-dessous : 🎜
  1. Sauvegardez les données d'origine et les fichiers de définition du tableau.
rrreee🎜Parmi eux, dbname et tablename représentent respectivement les noms de base de données et de table à sauvegarder. 🎜
  1. Modifiez les règles d'encodage et de tri des caractères du tableau.
rrreee🎜Parmi eux, table_name représente le nom de la table dont l'encodage des caractères doit être modifié. 🎜🎜Après avoir exécuté la commande ci-dessus, MySQL modifiera l'encodage et le classement de tous les champs de type de caractères de la table en utf8mb4 et utf8mb4_unicode_ci. 🎜🎜Modifier l'encodage des caractères du champ🎜🎜Si vous souhaitez uniquement modifier l'encodage des caractères d'un champ du tableau, vous pouvez suivre les étapes ci-dessous : 🎜
  1. Sauvegarder les données.
rrreee🎜Parmi eux, dbname et tablename représentent respectivement les noms de base de données et de table à sauvegarder. 🎜
  1. Modifiez l'encodage des caractères du champ.
rrreee🎜Parmi eux, tablename et column_name représentent respectivement les noms de table et de champ dont l'encodage des caractères est à modifier. 🎜🎜Après avoir exécuté la commande ci-dessus, MySQL modifiera le codage des caractères et le classement de ce champ en utf8mb4 et utf8mb4_unicode_ci. 🎜🎜Résumé🎜🎜La définition correcte du codage des caractères est très importante pour la sauvegarde et l'interrogation des données. Dans MySQL, nous pouvons modifier les règles de codage des caractères et de classement des bases de données, tables et champs existants via les méthodes ci-dessus. Il convient de noter qu'avant d'effectuer les opérations ci-dessus, assurez-vous de sauvegarder les données d'origine ou le fichier de définition de base de données pour éviter toute perte de données. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn