在MySQL5.7的版本的数据库中使用下面语句建库建表,
create database mydb;
use dabatabse mydb;
create table mytable(id int,name varchar(20));
insert into table values(1,'张三');
然后就会报以下错误:
ERROR 1366 (HY000): Incorrect string value: '\xE5\xBC\xA0\xE4\xB8\x89' for column 'name' at row 1
这时是因为中文乱码问题导致插入数据错误,排除方法很简单,使用下面的代码查看数据的编码
show database mydb;
可以得到一下结果:
从而我们看出这个数据的编码为拉丁文,是支持中文的。
解决方案也很简单:
1.首先在xshell6中使用一下命令:
vi /etc/my.cnf
这是修改mysql的配置文件,只需要在最后一行加上character_set_server=utf8并保存退出,然后使用systemctl restar mysqld重启mysql服务,然后使用systemctl status mysqld查看mysql状态。
这时我们还需要使用
alter database mydb character set 'utf8';
alter table mytable convert to character set 'utf8';
更改database和table的编码,至此就可以支持中文数据了。