mysql安插中文亂碼

來源:互聯網
上載者:User
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;
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.