解決php mysql查詢插入中文亂碼問(wèn)題

字號(hào):


    一.中文問(wèn)題其實(shí)就是經(jīng)統(tǒng)一編碼了否則就會(huì)亂碼
    1.數(shù)據(jù)庫(kù)與php頁(yè)面編碼統(tǒng)一
    2.數(shù)據(jù)庫(kù)數(shù)據(jù)表字段與頁(yè)面編碼統(tǒng)一
    如果做到上面兩種就不存在中文亂碼問(wèn)題了,那么我們來(lái)看mysql中文亂碼問(wèn)題解決例子
    1.我的mysql表如下
    --
    -- 表的結(jié)構(gòu) `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 '登陸次數(shù)',
    `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編碼了,這樣我來(lái)測(cè)試一個(gè)中文
    代碼如下:
    INSERT INTO `userain` (`id`, `我是中文`, `userpass`, `logins`, `logintime`, `mid`) VALUES
    (1, 'admin', '7c1f03139281878059b909c42ccf2f6a', 0, '2010-04-14 14:20:26', '1');
    我說(shuō)可以正常進(jìn)入也有人說(shuō)肯定不行其實(shí)關(guān)鍵不在sql語(yǔ)句了,重點(diǎn)在于php連接mysql數(shù)據(jù)時(shí)的編碼設(shè)置,如下。
    頁(yè)面編輯為gbk
    代碼如下:
    <?php
    //配置mysql數(shù)據(jù)庫(kù)連接參數(shù)
    $db = mysql_connect("localhost", "user","password");
    mysql_select_db("message",$db);
    //在執(zhí)行sql語(yǔ)句之前加上下面這一行
    ?>
    連接數(shù)據(jù)庫(kù)之后提交肯定是亂碼或保存不進(jìn)行了,如果要解決這個(gè)mysql中文亂碼問(wèn)題很簡(jiǎn)單在查詢處的
    代碼如下:
    <?php
    //配置mysql數(shù)據(jù)庫(kù)連接參數(shù)
    $db = mysql_connect(, "user","password");
    mysql_select_db("message",$db);
    //在執(zhí)行sql語(yǔ)句之前加上下面這一行
    mysql_query("SET NAMES 'utf8'",$db);
    這樣再提交你會(huì)發(fā)現(xiàn)就算你的頁(yè)面是gbk的提交的數(shù)據(jù)保存也會(huì)成功哦
    ps:對(duì)于ajax我們就一定要用uft8了,因?yàn)閍jax只支持uft8模式傳輸數(shù)據(jù)。