linux mysql中文乱码_linux下mysql中文乱码解决方法

上次在碰到这问题,在网上找了解决方法,可是没记下来。这星期要换机器,要把原来linux下的mysql数据库移到另一台服务器上。安装suse系统、再配置telnet、ftp服务、安装java jdk并配置、再安装eclipse和mysql,又花了一天的时间。感觉还是不熟练,配置防火墙老是不能将telnet和ftp服务排外。mysql又碰到了中文乱码问题,又在网上找一找,现在把解决方法先记下来吧。

系统环境:suse linux server 10,mysql 5.0

安装mysql后,默认的字符集是latin1。在linux下安装mysql不像在windows上安装那像,可以选择字符集(即使当时使用了默认的字符集,安装后也可以在安装目录下修改my.ini文件),但是在linux就不太一样了。

在shell输入mysql登陆后:

mysql>show variables like '%char%';

回车后显示:

+----------------------+---------------------

| variable_name | value

+-----------------------+---------------------

| character_set_client | latin1

| character_set_connection | latin1

| character_set_database | latin1

| character_set_filesystem | binary

| character_set_results | latin1

| character_set_server | latin1

| character_set_system | utf8

| character_sets_dir | /usr/share/mysql/charsets/

+---------------------+----------------------

这就是它默认的设置。

接下来到/usr/share/mysql/目录下,将http://www.ahsrst.cnf文件(使用其它实例配置文件也行)拷贝到/etc目录下:

pds:~# cp /usr/share/mysql/http://www.ahsrst.cnf /etc/http://www.ahsrst.cnf

pds:~# vi /etc/http://www.ahsrst.cnf

分别在如下几项中添加字符集:

[client]

default-character-set=gb2312

[mysqld_safe]

default-character-set=gb2312

[mysqld]

default-character-set=gb2312

#default-table-type=innodb

[mysql]

default-character-set=gb2312

再重启mysql让配置生效:

pds:~# service mysql restart

shutting down mysql done

starting mysql done

再次登陆mysql后,查看变量:

mysql>show variables like '%char%';

+----------------------+---------------------

| variable_name | value

+-----------------------+---------------------

| character_set_client | gb2312

| character_set_connection | gb2312

| character_set_database | gb2312

| character_set_filesystem | binary

| character_set_results | gb2312

| character_set_server | gb2312

| character_set_system | utf8

| character_sets_dir | /usr/share/mysql/charsets/

+---------------------+----------------------

如此显示就完成了配置了,在表中插入一条含中文的记录,就不再出现乱码,但是原来插入的记录很可能还是乱码,因为原来的字符集与当前字符集不一致。

linux中mysql中文乱码的解决方法2017-03-23 06:05 | #2楼

今天用java做了一个项目,发现往mysql中插入中文有乱码的现象,mysql乱码的情况可能有很多原因引起,于是在后台输出一行语句查看一下是否在项目里就出现乱码的问题,查看中文正常,难道是mysql字符集的问题,我查看了一下mysql的配置文件,这个文件的位置在/etc/mysql目录下,在终端运行

su root

获得管-理-员权限,运行

vi /etc/mysql/http://www.ahsrst.cnf

编辑配置文件,在[client]下加入

default-character-set =utf8

在[mysqld]下加入

default-character-set =utf8

退出编辑器,运行

sudo mysqladmin shutdown -uroot-p

回车,输入mysql密码,这样我重新部署一下我的项目,发现再次插入中文乱码解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值