一.中文問題其實就是經統一編碼了否則就會亂碼
1.資料庫與php頁面編碼統一
2.資料庫資料表欄位與頁面編碼統一
如果做到上面兩種就不存在中文亂碼問題了,那麼我們來看mysql中文亂碼問題解決例子
1.我的mysql表如下
--
-- 表的結構 `useradmin`
--
代碼如下 |
複製代碼 |
CREATE TABLE IF NOT EXISTS `userain` ( `id` int(4) NOT NULL AUTO_INCREMENT, `username` varchar(20) DEFAULT NULL, `userpass` varchar(40) DEFAULT NULL, `logins` int(4) NOT NULL DEFAULT '0' COMMENT '登陸次數', `logintime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `mid` char(1) NOT NULL DEFAULT '0', PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ; |
上面所有的都是utf8編碼了,這樣我來測試一個中文
代碼如下 |
複製代碼 |
INSERT INTO `userain` (`id`, `我是中文`, `userpass`, `logins`, `logintime`, `mid`) VALUES (1, 'admin', '7c1f03139281878059b909c42ccf2f6a', 0, '2010-04-14 14:20:26', '1'); |
我說可以正常進入也有人說肯定不行其實關鍵不在sql語句了,重點在於php串連mysql資料時的編碼設定,如下。
頁面編輯為gbk
代碼如下 |
複製代碼 |
<?php //配置mysql資料庫連接參數 $db = mysql_connect("localhost", "user","password"); mysql_select_db("message",$db); //在執行sql語句之前加上下面這一行 ?> |
串連資料庫之後提交肯定是亂碼或儲存不進行了,如果要解決這個mysql中文亂碼問題很簡單在查詢處的
代碼如下 |
複製代碼 |
<?php //配置mysql資料庫連接參數 $db = mysql_connect(www.111cn.net, "user","password"); mysql_select_db("message",$db); //在執行sql語句之前加上下面這一行 mysql_query("SET NAMES 'utf8'",$db); |
這樣再提交你會發現就算你的頁面是gbk的提交的資料儲存也會成功哦
ps:對於ajax我們就一定要用uft8了,因為ajax只支援uft8模式傳輸資料。