在PHP中PDO解決中文亂碼問題的一些補(bǔ)充
更新時間:2010年09月06日 12:27:51 作者:
前兩天了解了一下PDO連接數(shù)據(jù)庫的相關(guān)資料,配置相關(guān)在網(wǎng)路上都有很多相關(guān)資料,我在這里說說解決中文亂碼顯示問題
我的環(huán)境是appsver包,
在網(wǎng)上最常出現(xiàn)的解決中文亂碼顯示的代碼是:
第一種:PDO::__construct($dsn, $user, $pass, array
(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES'utf8';"));
我試過用第一種方法,可結(jié)果是,name字段只顯示一個‘C'字符。之后的本該顯示中文的地方卻是空白。
結(jié)果是這樣的:如圖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';");
第二種我也在我的環(huán)境里測試過,顯示效果如圖1所示,碰到這種情況,把utf8替換成GBK,就能顯
示了。另外,這里的PDO::在使用的時候用$pdo->代替,當(dāng)然,這個是個變量,變量名稱可以自己定義。
第三種:$pdo->query('set names utf8;');
至于第三種呢,看了上面兩種,應(yīng)該也知道要吧utf8替換成GBK,也能正確顯示了。
這幾種我都測試過了。都行。哈哈。另外,我在這里還介紹一種解決中文亂碼的一種方法,不過大同小異,
基本和第三種沒什么卻別,不通的是,這種方法,沒用query而是用exec,代碼如下:
$pdo->exec("SET CHARACTER SET GBK");
呵呵。怎么樣啊,這四種方法我都親自試過了。
在網(wǎng)上最常出現(xiàn)的解決中文亂碼顯示的代碼是:
第一種:PDO::__construct($dsn, $user, $pass, array
(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES'utf8';"));
我試過用第一種方法,可結(jié)果是,name字段只顯示一個‘C'字符。之后的本該顯示中文的地方卻是空白。
結(jié)果是這樣的:如圖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';");
第二種我也在我的環(huán)境里測試過,顯示效果如圖1所示,碰到這種情況,把utf8替換成GBK,就能顯
示了。另外,這里的PDO::在使用的時候用$pdo->代替,當(dāng)然,這個是個變量,變量名稱可以自己定義。
第三種:$pdo->query('set names utf8;');
至于第三種呢,看了上面兩種,應(yīng)該也知道要吧utf8替換成GBK,也能正確顯示了。
這幾種我都測試過了。都行。哈哈。另外,我在這里還介紹一種解決中文亂碼的一種方法,不過大同小異,
基本和第三種沒什么卻別,不通的是,這種方法,沒用query而是用exec,代碼如下:
$pdo->exec("SET CHARACTER SET GBK");
呵呵。怎么樣啊,這四種方法我都親自試過了。
相關(guān)文章
JS(jQuery)實現(xiàn)聊天接收到消息語言自動提醒功能詳解【提示“您有新的消息請注意查收”】
這篇文章主要介紹了JS(jQuery)實現(xiàn)聊天接收到消息語言自動提醒功能,結(jié)合實例形式詳細(xì)分析了javascript結(jié)合ajax后臺交互實現(xiàn)信息語音提示功能相關(guān)原理與操作技巧,需要的朋友可以參考下2019-04-04PHP編程實現(xiàn)的TCP服務(wù)端和客戶端功能示例
這篇文章主要介紹了PHP編程實現(xiàn)的TCP服務(wù)端和客戶端功能,結(jié)合實例形式分析了php基于socket實現(xiàn)TCP服務(wù)器端與客戶端通信功能的相關(guān)配置、定義與使用技巧,需要的朋友可以參考下2018-04-04php生成SessionID和圖片校驗碼的思路和實現(xiàn)代碼
做一個后臺登陸需要用到校驗碼,前臺的用戶跟蹤需要用到SessionID,當(dāng)然,默認(rèn)的PHP開啟了Session以后就有了一個SessionID,但是我需要自己的,并且能夠存儲進(jìn)數(shù)據(jù)庫,那么我就嘗試了一下,構(gòu)造了以下的函數(shù)。2009-03-03PHP中全局變量global和$GLOBALS[]的區(qū)別分析
$GLOBALS['var']是外部的全局變量本身,global $var是外部$var的同名引用或者指針2012-08-08PHP的構(gòu)造方法,析構(gòu)方法和this關(guān)鍵字詳細(xì)介紹
這篇文章介紹了PHP的構(gòu)造方法,析構(gòu)方法和this關(guān)鍵字,有需要的朋友可以參考一下2013-10-10執(zhí)行、獲取遠(yuǎn)程代碼返回:file_get_contents 超時處理的問題詳解
本篇文章是對執(zhí)行、獲取遠(yuǎn)程代碼返回:file_get_contents 超時處理的問題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06