MySQL5.7版本中sql语句中插入中文乱码解决方案

  在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的编码,至此就可以支持中文数据了。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值