在PHP中PDO解决中文乱码问题的一些补充
更新时间:2010年09月06日 12:27:51 作者:
前两天了解了一下PDO连接数据库的相关资料,配置相关在网路上都有很多相关资料,我在这里说说解决中文乱码显示问题
我的环境是appsver包,
在网上最常出现的解决中文乱码显示的代码是:
第一种:PDO::__construct($dsn, $user, $pass, array
(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES'utf8';"));
我试过用第一种方法,可结果是,name字段只显示一个‘C'字符。之后的本该显示中文的地方却是空白。
结果是这样的:如图1示

我是只要解决的:直接将UTF8替换成了GBK,就可以了,即:
PDO::__construct($dsn, $user, $pass, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET
NAMES'GBK';"));
效果图2如下:

第二种:PDO::__construct($dsn, $user, $pass);
PDO::exec("SET NAMES 'utf8';");
第二种我也在我的环境里测试过,显示效果如图1所示,碰到这种情况,把utf8替换成GBK,就能显
示了。另外,这里的PDO::在使用的时候用$pdo->代替,当然,这个是个变量,变量名称可以自己定义。
第三种:$pdo->query('set names utf8;');
至于第三种呢,看了上面两种,应该也知道要吧utf8替换成GBK,也能正确显示了。
这几种我都测试过了。都行。哈哈。另外,我在这里还介绍一种解决中文乱码的一种方法,不过大同小异,
基本和第三种没什么却别,不通的是,这种方法,没用query而是用exec,代码如下:
$pdo->exec("SET CHARACTER SET GBK");
呵呵。怎么样啊,这四种方法我都亲自试过了。
在网上最常出现的解决中文乱码显示的代码是:
第一种:PDO::__construct($dsn, $user, $pass, array
(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES'utf8';"));
我试过用第一种方法,可结果是,name字段只显示一个‘C'字符。之后的本该显示中文的地方却是空白。
结果是这样的:如图1示

我是只要解决的:直接将UTF8替换成了GBK,就可以了,即:
PDO::__construct($dsn, $user, $pass, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET
NAMES'GBK';"));
效果图2如下:

第二种:PDO::__construct($dsn, $user, $pass);
PDO::exec("SET NAMES 'utf8';");
第二种我也在我的环境里测试过,显示效果如图1所示,碰到这种情况,把utf8替换成GBK,就能显
示了。另外,这里的PDO::在使用的时候用$pdo->代替,当然,这个是个变量,变量名称可以自己定义。
第三种:$pdo->query('set names utf8;');
至于第三种呢,看了上面两种,应该也知道要吧utf8替换成GBK,也能正确显示了。
这几种我都测试过了。都行。哈哈。另外,我在这里还介绍一种解决中文乱码的一种方法,不过大同小异,
基本和第三种没什么却别,不通的是,这种方法,没用query而是用exec,代码如下:
$pdo->exec("SET CHARACTER SET GBK");
呵呵。怎么样啊,这四种方法我都亲自试过了。
相关文章
ThinkPHP基于think-queue的队列插件实现消息推送
think-queue是ThinkPHP官方提供的一个消息队列服务,是专门支持队列服务的扩展包。think-queue消息队列适用于大并发或返回结果时间比较长且需要批量操作的第三方接口,可用于短信发送、邮件发送、APP推送。2022-12-12
php数组函数序列之rsort() - 对数组的元素值进行降序排序
rsort() 函数对数组的元素按照键值进行逆向排序。与 arsort() 的功能基本相同。注释:该函数为 array 中的单元赋予新的键名。这将删除原有的键名而不仅是重新排序。2011-11-11
深入探讨:PHP使用数据库永久连接方式操作MySQL的是与非
本篇文章是对PHP使用数据库永久连接方式操作MySQL的是与非进行了详细的分析介绍,需要的朋友参考下2013-06-06


最新评论