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