mysql中的表无法插入含有中文字符的记录

在Ubuntu18环境下,使用MySQL5.7时遇到新建表无法插入中文记录的问题。原因是数据库字符集不支持中文。解决方案包括:1) 修改mysql配置文件,将字符集设置为utf8;2) 重启mysql服务器;3) 修改数据库和表的字符集为utf8。通过这些步骤,成功解决了中文插入问题。
摘要由CSDN通过智能技术生成

mysql版本是mysql5.7,系统环境是ubuntu18。版本影响不大。
问题来源:
我新建了了一个数据库mydb,然后在库中新建了一张表mytb,在mytb中插入含中文的记录时,提示错误。
问题的原因:
是数据库底层存储表的字符集不支持中文,因此要修改数据库的字符集。
解决这个问题需要三个步骤:

  1. 修改mysql的配置文件字符集为utf8;
  2. 重启mysql服务器;
  3. 修改之前已创建数据库和表的字符集为utf8。

步骤一:
先找到配置文件,一般mysql的加载的配置文件依次为:

/etc/my.cnf /etc/mysql/my.cnf ~/.my.cnf 

也可以通过以下命令查看mysql加载了哪些配置文件,以及加载配置文件的顺序:

mysql --help|grep 'my.cnf'

多个配置文件有优先级,优先加载/etc/my.cnf,其次加载/etc/mysql/my.cnf,最后加载~/.my.cnf ,同一个变量,早加载的会覆盖掉后加载的。
在我的系统中上没找到/etc/my.cnf文件,但是找到了/etc/mysql/my.cnf文件,然后在/etc/mysql/my.cnf文件中添加如下代码;

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci

其中collation-server=utf8_general_ci表示不区分大小写用utf8字符集检验。

步骤二:
通过以下命令重启mysql服务器

sudo service mysql restart

步骤三:
在mysql终端下,输入以下命令查看数据库和表的字符集,此时的字符集应该是latin1:

mysql>show create database mydb;
mysql>use mydb;
mysql>show create table mytb;

然后通过以下命令修改数据库和表的字符集为utf8

mysql>alter database mydb character set utf8;
mysql>use mydb;
mysql>alter table mytb default character set utf8#修改mytb表的字符集
mysql>alter table mytb change name name varchar(30) character set utf8#修改mytb表中name字段的字符集

步骤四:
测试是否能插入中文:

insert into mytb values(2,'张三');
select * from mytb;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值