您的位置信息之舟电 脑硬件栏目首页数据库类MySQL 收藏本页

→ 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 信息之舟电脑之家收集整理推荐文章