Maison >base de données >tutoriel mysql >Comment modifier le classement dans MySQL

Comment modifier le classement dans MySQL

WBOY
WBOYoriginal
2022-05-26 17:24:305045parcourir

Méthode : 1. Définissez le fichier "my.cnf" et ajoutez "character_set_server=modified content" et "collation_server=modified content" sous mysqld ; 2. Utilisez "systemctl restart mysqld" pour redémarrer.

Comment modifier le classement dans MySQL

L'environnement d'exploitation de ce tutoriel : système windows10, version mysql8.0.22, ordinateur Dell G3.

Comment modifier le classement dans MySQL

[Problème d'erreur]
Lors de l'insertion de données dans la base de données, une erreur se produit lors de l'insertion de données chinoises dans un champ de type varchar.
Message d'erreur d'origine :
ERREUR 1366 (HY000) : Valeur de chaîne incorrecte : 'xE8xA5xBFxE5xAEx89' pour la colonne 'adresse'

[Analyse des causes]
Affichez les champs via le afficher les colonnes complètes de user_bean ; attribut de classement d'instruction, la valeur de l'attribut de classement du champ trouvé est show full columns from user_bean;语句查看字段的collation属性,发现字段的collation属性值是 latin1_swedish_ci ,说明字段默认为英语。未对汉语进行设置,所以当输入汉语时,mysql会报错为“字符串的值不正确”。

【解决方法】

1、编辑mysql的配置文件 /etc/my.cnfvi /etc/my.cnf

在 [mysqld] 下面加入两行补充

character_set_server=utf8
collation_server=utf8_general_ci

2、重启Mysql服务 systemctl restart mysqld

向数据库插入含中文的数据,成功!

注意:上面步骤可以解决以后创建表时字段的collation属性的问题,但前面已经创建的表字段的collation属性值并不会发生变化。
如果要改变之前已经创建好的表,怎么办?
方法1:对原来的表进行修改,可以通过类似语句
alter table user_bean change address address varchar(255) character set utf8 collate utf8_general_ci not null;latin1_swedish_ci
et le champ de description est par défaut en anglais. La langue chinoise n'a pas été définie, donc lors de la saisie du chinois, MySQL signalera une erreur du type "La valeur de la chaîne est incorrecte".

【Solution】

1. Modifiez le fichier de configuration mysql /etc/my.cnf, vi /etc/my.cnf

🎜Ajoutez deux lignes ci-dessous [mysqld] Supplément🎜
show full columns from 表名

vi /etc/my.cnf
character_set_server=utf8
collation_server=utf8_general_ci

systemctl restart mysqld

alter table 表名 change 要修改的字段 字段名 数据类型  character set utf8 collate utf8_general_ci 约束条件;
🎜2. Redémarrez le service Mysql systemctl restart mysqld🎜🎜Insérez les données chinoises dans la base de données, réussi ! 🎜🎜🎜Remarque🎜 : Les étapes ci-dessus peuvent résoudre le problème de l'attribut de classement des champs lors de la création de tables à l'avenir, mais les valeurs d'attribut de classement des champs de table précédemment créés ne changeront pas. 🎜🎜Que dois-je faire si je souhaite modifier un tableau qui a déjà été créé ? 🎜🎜 Méthode 1 : Pour modifier la table d'origine, vous pouvez utiliser des instructions similaires 🎜alter table user_bean change address adresse varchar(255) jeu de caractères utf8 collate utf8_general_ci not null ;🎜 Méthode 2 : Supprimer la table d'origine , reconstruisez à nouveau. 🎜🎜🎜【Résumé des commandes】🎜🎜rrreee🎜Apprentissage recommandé : 🎜Tutoriel vidéo MySQL🎜🎜

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