|
→ Linux下 Mysql 5 中文乱码的彻底解决及应用的一些注意事项
|
|
|
www.kepusoft.com 信息之舟电脑软件应用栏目
|
|
|
信息之舟电脑软件应用栏目编者按:
一. 自从mysql4.1开始,mysql对中文的支持问题是比较烦人的,怎么弄都乱码,如今mysql5 据说是mysql的新纪元,但从官方下载安装的mysql5仍存在乱码现象,这里就是针对此现象做的讨论:
建议最好是下载mysql的源码进行编译,这是由于官方编译的mysql的默认支持编码是latin字符集,所以中文字符在数据库里查看的时候看到的是乱码。编译MySQL时使用withcharset=编码,可以方便地把mysql编译成该编码形式,这样MySQL就会直接支持中文查找和排序,– with-extra-charsets参数指定其它可用的字符集。
下载并解压源码包,打开INSTALL-SOURCE,这里介绍了linux下详细的安装方法,所以大家所要注意的只是下面的configure指令:
groupadd mysql
useradd -g mysql mysql
./configure –with-charset=gbk –with-collation=gbk_chinese_ci –with-extra-charsets=gb2312,big5,utf8,binary,ascii –prefix=/usr/local/mysql
make
make install
cp support-files/my-medium.cnf /etc/my.cnf
cd /usr/local/mysql
bin/mysql_install_db –user=mysql
chown -R root .
chown -R mysql var
chgrp -R mysql .
bin/mysqld_safe –user=mysql &
bin/mysql
mysql> show variables;
你可以看到全局的字符集参数全是gbk,gb2312字集应该包含在gbk里,所以不讨论。
进行和平常mysql4.0一样的php操作,你会发现仍然出现中文乱码现象。
这里要说明的是:从mysql 4.1开始,必需在mysql数据库连接后对应用的字符集做出说明,否则非英文字母的文字存取都无法解释变成?号。
解决方法就是要适应新版mysql的要求:
在连接mysql数据库后执行set character set 字符集,该指令在最新版的mysql 5如果默认字集和存储相符可以免设:
set character set gbk;
在php里应该是这么写:mysql_query(”set character set gbk”);
指令大小写均可
phpwind和discuz是广泛应用的国产php论坛,大量的朋友在应用它,了解了以上步骤,你也可以对论坛源码进行很小的修改,安全地把数据库升级到mysql5:
找到include/db_mysql.php,修改function connect(…){…..}
在选择数据库mysql_select_db($dbname);后面加上一句mysql_query(’set character set gbk’);存盘。
二. 文件的导入导出:如果存入非gbk字符,这时候你需要先在导入文件的头部加一行: SET NAMES ‘字符集’; 并注意最后也是;号,别漏了。
文件导入和导出执行
mysql -u用户名 -p密码 数据库名
mysqldump -u用户名 -p密码 数据库名>data.sql
如果用mysqldump导出数据出现了乱码也没有关系,可以运行iconv来转换一下:
iconv -c -f utf8 -t gbk 库文件名>新的gbk的库文件名
综上所述,你要注意:
1。尽量在需要导入的库文件的开头加入set names ‘gbk’;告诉mysql你要导入的是一个gbk的文件;
2。在mysql上使用 show variables;或show variables like ‘character_set_%’; 用来查看当前的字集状态。
3。如果出现乱码也不要怕,其一是你要注意留存原有的备份,其二是用iconv来进行转化。
 |
|
www.kepusoft.com
信息之舟电脑之家收集整理推荐文章
|
|
|
|
|
|
|