mysql插入中文亂碼
php檔案裡設定了網頁編碼為utf-8
header("Content-type:text/html; charset=utf-8");
插入資料庫前設定了傳遞給資料庫的編碼為utf-8
$this->mysqli->query("set names utf8");
資料庫中,設定了一些字元集有關的變數
查詢show variables like 'char%';後結果為
查詢show variables like 'collation_%';後結果為
我用的WampServer,修改mysql設定檔my.ini,在[client]節點下添加default-character-set=utf8 ,在[mysqld]節點下添加character_set_server=utf8,然後重啟musql服務
但是傳到資料庫裡,中文字元都變成了問號。。請問應該如何設定才能解決亂碼?
分享到:
------解決方案--------------------
把你做的所有修改都還原的初始狀態!
需要注意的是:
1、所有與字元集相關的設定,都不會影響到資料庫中的已有資料
2、字元集相關的設定,只對設定後插入的資料生效
3、資料庫是共有資源,不要輕易修改設定。以免引發其他應用的問題
只要做到以下兩點,就不會出現亂碼問題
1、所有可能會有中文內容的欄位,都需要有中文字元集的串連校對。至於是哪個字元集都無所謂(gbk、utf8、ucs2都可以)也不需要每個欄位都相同
2、每次在串連資料庫之後,執行一次 set name 頁面字元集
------解決方案--------------------
刪去原表
drop table tb_userinfo
重新建立
CREATE TABLE `tb_userinfo` (
`id` int(20) NOT NULL AUTO_INCREMENT,
`username` varchar(20) DEFAULT NULL,
`password` varchar(20) DEFAULT NULL,
`email` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=90 DEFAULT CHARSET=utf8
其實可以不用這麼做
只需修改串連校對就可以了
ALTER TABLE `tb_userinfo` CHANGE `username` `username` VARCHAR( 20 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL
------解決方案--------------------
改了表字元集,欄位也是要改的,你就drop table; 後再重建立表。
CREATE TABLE `tb_userinfo` (
`id` int(20) NOT NULL AUTO_INCREMENT,
`username` varchar(20) DEFAULT NULL,
`password` varchar(20) DEFAULT NULL,
`email` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=90 DEFAULT CHARSET=utf8;