- 相关推荐
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.oh100.comf文件(使用其它实例配置文件也行)拷贝到/etc目录下:
pds:~# cp /usr/share/mysql/http://www.oh100.comf /etc/http://www.oh100.comf
pds:~# vi /etc/http://www.oh100.comf
分别在如下几项中添加字符集:
[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.oh100.comf
编辑配置文件,在[client]下加入
default-character-set =utf8
在[mysqld]下加入
default-character-set =utf8
退出编辑器,运行
sudo mysqladmin shutdown -uroot-p
回车,输入mysql密码,这样我重新部署一下我的项目,发现再次插入中文乱码解决。
【linux下mysql中文乱码解决方法】相关文章:
mysql数据库面试问题04-05
linux工程师岗位职责02-02
linux工程师岗位职责15篇02-02
linux工程师岗位职责(15篇)02-02
铸件缺陷及解决方法03-07
油漆缺陷及解决方法04-22
环境污染的解决方法05-26
短波通信盲区及解决方法03-15
UPS常见故障及解决方法03-02
注塑品常见缺陷及解决方法03-15