程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 解決php mysql查詢插入中文亂碼問題

解決php mysql查詢插入中文亂碼問題

編輯:關於PHP編程

       一.中文問題其實就是經統一編碼了否則就會亂碼

      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.45it.net, "user","password");
    mysql_select_db("message",$db);
    //在執行sql語句之前加上下面這一行
    mysql_query("SET NAMES 'utf8'",$db);

      這樣再提交你會發現就算你的頁面是gbk的提交的數據保存也會成功哦

      ps:對於ajax我們就一定要用uft8了,因為ajax只支持uft8模式傳輸數據。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved