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

來源:互聯網
上載者:User

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

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模式傳輸資料。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.