首頁 >後端開發 >PHP問題 >怎麼解php pdo亂碼

怎麼解php pdo亂碼

藏色散人
藏色散人原創
2020-07-07 11:16:373093瀏覽

php pdo亂碼的解決方法:1、設定語句「PDO::exec(“SET NAMES 'utf8';”);」;2、使用「$pdo->query('set names utf8 ;');」方法;3、用exec方法解決。

怎麼解php pdo亂碼

PHP中PDO解決中文亂碼

網路上最常出現的解決中文亂碼顯示的程式碼是:

第一種:PDO::__construct($dsn, $user, $pass, array

(PDO::MYSQL_ATTR_INIT_COMMAND => “SET NAMES’utf8′;”));

我試過用第一種方法,可結果是,name字段只顯示一個'C'字元。之後的本該顯示中文的地方卻是空白。

結果是這樣的:如圖所示


我只要解決的:直接將UTF8替換成了GBK,就可以了,也就是:

PDO::__construct($dsn, $user, $pass, array(PDO::MYSQL_ATTR_INIT_COMMAND => “SET NAMES’GBK’;”));

效果圖如下:

##第二種: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”);

以上幾種方法測試過,都能解決中文亂碼問題。

更多相關知識,請造訪

PHP中文網

以上是怎麼解php pdo亂碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn