go mysql 乱码_linux下mysql中文乱码问题解决办法-Go语言中文社区

linux下Mysql中文乱码问题解决办法

一、lampp环境下的数据库乱码问题

问题描述:

在做mysql练习的时候发现新创建的数据库中插入数据表中的记录中文出现乱码的问题,如下图:

e3fee64db97fa8bde80e7a69f136b2e1.png

经过多方查证,整里如下文挡:

前提:

我自己的环境是使用的lampp下的mysql,该配置文件是在/opt/lampp/etc/my.cnf;如果是自己安装的mysql,那么配置文件一般都在/etc/my.cnf

解决办法:

1、首先进入msyql,然后使用show variables like 'character%' ,执行编码显示,可以看到如下图所示:

8f215b0dc9d066335f07ebec698587ab.png

默认的是客户端和服务器都用了latin1,所以会乱码。

2、修改/opt/lampp/etc/my.cof文件

48304ba5e6f9fe08f3fa1abda7d326ab.png

[client]

#password = your_password

port = 3306

socket = /opt/lampp/var/mysql/mysql.sock

default-character-set=utf8 //添加该语句

[mysqld]

user = mysql

port=3306

socket = /opt/lampp/var/mysql/mysql.sock

skip-external-locking

key_buffer = 16M

max_allowed_packet = 1M

table_open_cache = 64

sort_buffer_size = 512K

net_buffer_length = 8K

read_buffer_size = 256K

read_rnd_buffer_size = 512K

myisam_sort_buffer_size = 8M

character_set_server=utf8 //添加该语句

[mysql]

no-auto-rehash

default-character-set=utf8 //添加该语句

48304ba5e6f9fe08f3fa1abda7d326ab.png

在mysql,mysqld,client下分别添加如上语句

注意:如果修改后不能启动报错试试把default-character-set=utf8改为character_set_server=utf8;我这里遇到了该问题,所以去掉了default后就正常了 ,脚本中没有使用default-character-set=utf8。

3、使用命令drop database 数据库名,删除创建的数据库

4、重启mysql的服务:/opt/lampp/lampp restart

5、重新创建数据库及表结构,再次插入数据即可正常使用,如下图:

ca8cda590924b30f805bb522181d1054.png

方法2:

网上还有另外一种使用SQL语句修改编码值的,但是我试了一下,通过SQL语句是可以修改编码值,但是重启mysql服务后还是会变回原来的值,而且即便使用SQL语句修改过来后在重新创建数据表在插入数据还是会产生乱码(也可能哪里操做不对,但是不我提倡这么修改)

使用SQL语句修改的方法:

1、首先进入mysql,然后在mysql下执行如下语句:

SET character_set_database = utf8;

SET character_set_server = utf8;

2、使用命令show variables like 'character%' ,执行编码显示,可以看到如下图所示:

d50e7737b76d94cd408a9d082f19d8fd.png

3、在使用create database test;创建数据库,在该库中创建数据表,然后在插入数据,查看是否正常!

二、linux下yum自动安装MySQL乱码问题解决办法

******************************************************************************************************************************************************

如果使用yum方法自动安装的MySQL服务,则MySQL的配置文件是在/etc/my.cnf;修改该文件的时候可能出现该文件中只有[mysqld]、[mysqld_safe],如果我们只是在mysqld下边加入

default-character-set=utf8,无法将所有的选项都修改为utf8的格式,如下图:

113498e275dd9fbddb95fd2f8b404455.png

所以这里我们需要在my.cnf文件下手动配置[client]选项并在该选项下加入:default-character-set=utf8即可,如下图:

acb928a830e7e218dea3373b1ab90b67.png

添加完成后重启MySQL的服务,然后在重新创建数据库和数据表,之后在使用第三方管理工具连接就不会出现乱码的问题了,如下图。

eb42c6762dae932f26e3c52a75ba2db6.png

总之遇到乱码的问题,可以通过show variables like 'character%' ; 该命令进行查看,将字符集设置成utf8后基本都会解决掉。

*******************************************************************************************************************************************************

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值