我自己測試一下,很多字符變成了 ‘?'。
數(shù)據(jù)庫連接已經(jīng)是使用了 utf8 字符集:
define("MYSQL_ENCODE", "UTF8");
mysql_query('SET NAMES '.MYSQL_ENCODE,$conn) or die('字符集設(shè)置錯(cuò)誤'.mysql_error());
搞了大半小時(shí),沒有搞定。
insert 的數(shù)據(jù)都是仍然亂碼,突然想,是不是字段不能保存這些越南文。
我看一下數(shù)據(jù)庫字符集,默認(rèn)都是 gbk,這個(gè)對中文是沒有問題的,一碰到越南文,就亂碼了。
于是,我將可能用到越南文的字段的字符集修改為 utf8,校對修改為:utf8_unicode_ci。(這里一定要具體修改某個(gè)字段,修改整個(gè)表的字符集,不起作用,字段還是保留著原來的字符集)問題解決。
我的數(shù)據(jù)庫為:php_college_web
表:city_article
用到越南文的字段:title,content
于是執(zhí)行如下sql:
ALTER TABLE city_article CHANGE title title VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci
ALTER TABLE city_article CHANGE content content text CHARACTER SET utf8 COLLATE utf8_unicode_ci