各位用户为了找寻关于Linux系统下修改mysql字符集为UTF8步骤的资料费劲了很多周折。这里教程网为您整理了关于Linux系统下修改mysql字符集为UTF8步骤的相关资料,仅供查阅,以下为您介绍关于Linux系统下修改mysql字符集为UTF8步骤的详细内容
目录
1、数据库中查看mysql状态: 2、修改配置文件: 3、若是还没成功,可能是创建mysql时的配置或者刚上一步mysql没有停止服务编辑 my.cnf 配置文件。linux上修改mysql字符编码为utf8
开始在linux上装好了mysql服务,在后期的使用过程中,突然发现在插入记录时,部分字段不能为中文,报错信息如下:
? 1 2mysql>
insert
into
syudent
values
(1,
'陶盼'
,21);
error 1366 (hy000): incorrect string value:
'xe9x99xb6xe7x9bxbc'
for
column
'name'
at
row 1
经过我坚持不懈的查找资料,终于解决了该问题。下面给大家分享我的解决方法:
1、数据库中查看mysql状态:
? 1 2 3# 查看mysql状态
mysql> status;
mysql> quit;
2、修改配置文件:
? 1 2 3 4 5 6 7 8 9#退出数据库
systemctl stop mysqld.service
#编辑my.cnf配置文件
vim /etc/my.cnf
[client] //如果没有[client]段,就自己添加上去
default
-
character
-
set
=utf8
[mysqld]
character
-
set
-server=utf8
collation-server=utf8_general_ci
编辑好配置文件后,重启mysql服务;
? 1systemctl start mysqld
重启成功后,重新查询一下mysql的状态,显示如下即可:
? 1 2mysql -u root -p
'你的密码'
mysql> status;
这时候进入数据库即可正常插入中包含文字段数据了。
3、若是还没成功,可能是创建mysql时的配置或者刚上一步mysql没有停止服务编辑 my.cnf 配置文件。
这里我们还需对表和字段设置字符集为utf8;
? 1 2 3#查看一下表的创建过程
mysql> use ky15;
mysql> show
create
table
syudent;
#将表的字符集设置为utf8
mysql>
alter
table
表名
character
set
utf8;
#将想要插入中文的字段的字符集改为utf8
mysql>
alter
table
表名 change
name
name
char
(20)
character
set
utf8;
#查看表的字符集和字段的字符集
mysql> show
create
table
syudent;
#测试,插入中文
mysql>
insert
into
syudent
values
(1,
'陶盼'
,21);
mysql>
insert
into
syudent
values
(2,
'王旭'
,21);
mysql>
select
*
from
syudent;
到此这篇关于linux系统下修改mysql字符集为utf8步骤的文章就介绍到这了,更多相关linux修改mysql字符集内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
原文链接:https://blog.csdn.net/weixin_53060366/article/details/121643860