MySQL 4.1x 中文乱码问题

2016-01-29 14:58 5 1 收藏

MySQL 4.1x 中文乱码问题,MySQL 4.1x 中文乱码问题

【 tulaoshi.com - MySQL 】

现在多数host装的还是MySQL 4.0x 版本以下,如果升级到了4.1x 或者移动到使用4.1x 的主机上,估计会遇到一些问题。我在powweb上遇到了两个问题。

一是数据导入。在phpMyAdmin内导入后,发现中文变成了乱码。搜索学习后,了解到需要设置数据库的collation (校勘),如果你的数据库是utf-8的,设置为utf8_general_ci就可以了。

二是,即使正确导入了,在phpMyAdmin里也能正确显示,但WordPress页面上显示的文章内容都是“???”,而模板里面的汉字都能正常显示。这让我头疼了很久。搜索到Windix’s Weblog上有对此的说明:

从MySQL 4.1开始引入的多语言支持确实很棒,而且一些特性已经超过了其他的数据库系统。不过我在测试过程中发现使用适用于MySQL 4.1之前的PHP语句操作MySQL数据库会造成乱码,即使是设置过了表字符集也是如此。我读了一下新的MySQL在线手册中第十章”Character Set Support“后终于找到了解决方法并测试通过。

MySQL 4.1的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。

当我们按照原来的方式通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/mysql/)

SET NAMES ‘utf8′;

但是我依旧不知道,如何,在何处让WordPress运行这个SQL语句。后来在阿修的部落格上查到办法:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/mysql/)

為著解決這個問題必須去修改wp-includes/wp-db.php內的資料連線設定。詳細的修改方式是這樣的:

$this-dbh = @mysql_connect($dbhost,$dbuser,$dbpassword);
//加上下面這行
$this-query("SET NAMES 'utf8'");

这样子终于能正常显示中文的WordPress了。虽然后来还是没用Powweb,但是觉得这个经验会对别人有用。记得有人用email和我讨论过这样子的中文显示问题,但是我那时哪里知道问题出在MySQL 4.1x上。

还有,4.1x的数据库不向下兼容,所以升级的时候要三思啊。

来源:https://www.tulaoshi.com/n/20160129/1494867.html

延伸阅读
标签: Web开发
网上有很多解决这个问题的方法,试了一下都不好用,自己就对于这些方法测试了一下,然后逐个排除无用的设置,最后得到了最简单的方案。 js代码: 得到XmlHttpRequest的类 Code 1function HttpRequest() 2{ 3 //取得Request对象 4 this.Request=function(){ 5 try 6 { 7 if(window.XMLHttpRequest) request=new XMLHttpRequest(); 8 if(!reque...
标签: MySQL mysql数据库
作者: www.quicklinux.org 邮件: support@quicklinux.org MySQL4.1是比较烦人.支持多语言的细化设置.再加上PhpMyadmin-2.6也比较笨.默认就是改不动的UTF-8.怎么弄都乱码.好了.废话少说.我们来一步步解决这个问题: 1. 修改 /etc/my.cnf 文件.改成如下内容: [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock default-chara...
第一个方法: MySQL 4.1 中文乱码的问题 最近要将 MySQL 4.0 升级到 MySQL 4.1 ,发现了中文乱码的问题,希望以下见解对大家有用。 1. MySQL 4.1 在文字上有很大改进,它有了 Character Set 与 Collation 的慨念。 2. 在 MySQL 4.0 ,一般的程式都会将文字以拉丁文 ( latin) 来储存,就算我们输入中文字,结果仍是放在以拉丁文设置的文字栏...
标签: Web开发
jsp中文乱码 jsp mysql 乱码要servlet里面支持中文的方法: 在dopost或者doget的第一句加上: request.setCharacterEncoding("GB2312"); response.setCharacterEncoding("GB2312"); jsp乱码问题在jsp里面就把 %@ page contentType="text/html; charset=gb2312" language="java" import="jav...
标签: MySQL mysql数据库
1 设置phpMyAdminLanguage:Chinese simplified (zh-utf-8)MySQL 字符集:UTF-8 Unicode (utf8)MySQL 连接校对 gbk_chinese_ci2 创建数据库时整理设置成 gbk_chinese_ci3 用SQL建立表中ENGINE=MyISAM DEFAULT CHARSET=gbk;ENGINE=InnoDB DEFAULT CHARSET=gbk AUTO_INCREMENT=40 ;4 检查表结构中varchar(100) 的整理属性为gbk_chinese_ci其它类型...

经验教程

241

收藏

6
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部