>  기사  >  데이터 베이스  >  mysql에서 데이터 정렬을 수정하는 방법

mysql에서 데이터 정렬을 수정하는 방법

WBOY
WBOY원래의
2022-05-26 17:24:304996검색

방법: 1. "my.cnf" 파일을 설정하고 mysqld 아래에 "character_set_server=modified content" 및 "collation_server=modified content"를 추가합니다. 2. "systemctl restart mysqld"를 사용하여 다시 시작합니다.

mysql에서 데이터 정렬을 수정하는 방법

이 튜토리얼의 운영 환경: windows10 시스템, mysql8.0.22 버전, Dell G3 컴퓨터.

mysql에서 collation을 수정하는 방법

[문제 오류]
데이터베이스에 데이터를 삽입할 때 varchar 유형 필드에 중국어 데이터를 삽입하면 오류가 발생합니다.
원래 오류 텍스트:
ERROR 1366(HY000): 잘못된 문자열 값: 'address' 열의 'xE8xA5xBFxE5xAEx89'

[원인 분석]
show full columns from user_bean;을 통해 필드를 확인하세요. > 문 대조 속성인 경우, 찾은 필드의 대조 속성 값은 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
이고, 설명 필드는 기본적으로 영어로 설정되어 있습니다. 중국어가 설정되어 있지 않아 중국어를 입력하면 mysql에서 "문자열의 값이 잘못되었습니다."라는 오류를 보고합니다.

【해결책】

1. mysql 구성 파일 /etc/my.cnf, vi /etc/my.cnf

🎜아래 두 줄 추가 [mysqld] 보충🎜
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. MySQL 서비스를 다시 시작하세요. systemctl restart mysqld🎜🎜중국어 데이터를 데이터베이스에 삽입하세요! 🎜🎜🎜Note🎜: 위 단계를 통해 나중에 테이블을 생성할 때 필드의 데이터 정렬 속성 문제를 해결할 수 있지만 이전에 생성된 테이블 필드의 데이터 정렬 속성 값은 변경되지 않습니다. 🎜🎜이전에 생성된 테이블을 변경하려면 어떻게 해야 하나요? 🎜🎜 방법 1: 원본 테이블을 수정하려면 유사한 문을 사용할 수 있습니다. 🎜alter table user_bean 주소 주소 변경 varchar(255) 문자 세트 utf8 collate utf8_general_ci not null;🎜 방법 2: 원본 테이블 삭제 , 다시 재구축하세요. 🎜🎜🎜【명령 요약】🎜🎜rrreee🎜추천 학습: 🎜mysql 비디오 튜토리얼🎜🎜

위 내용은 mysql에서 데이터 정렬을 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.