|
php操作數(shù)據(jù)庫的時(shí)候,數(shù)據(jù)庫中數(shù)據(jù)使用UTF8編碼,在讀出來的時(shí)候,顯示的全是???????問號(hào)亂碼,找了一些資料原來是在讀取之前進(jìn)行一次編碼設(shè)置:
復(fù)制代碼 代碼如下:
create table tablename
(
id int not null auto_increment,
title varchar(20) not null,
contNET varchar(300) defalut null,
primary key ('id')
)begin=MyISAM DEFAULT CHARSET =UTF8;
在插入數(shù)據(jù)之前執(zhí)行:
復(fù)制代碼 代碼如下:
mysql_query("SET NAMES utf8");
然后
mysql_query("insert into tablename .....")
讀出數(shù)據(jù)之前執(zhí)行:
復(fù)制代碼 代碼如下:
mysql_query("SET NAMES utf8");
然后 mysql_query("select * from tablename")
注意:此處讀出的編碼是把原來編碼的內(nèi)容重新經(jīng)過編碼后輸出的,比如輸出內(nèi)容所在頁面是GBK編碼,那么在讀出的時(shí)候在頁面顯示也為亂碼,所以在查詢之前執(zhí)行 mysql_query("SET NAMES gbk"),在頁面就可以正常顯示GBK編碼的文字內(nèi)容 。
php技術(shù):PHP MYSQL亂碼問題,使用SET NAMES utf8校正,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。