欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL的中文UTF8亂碼問題

 更新時(shí)間:2010年05月09日 11:00:46   作者:  
MySQL從4.x版本開始支持Unicode,3.x只有l(wèi)atin1編碼。剛工作的時(shí)候就開始用MySQL了,用的php存取,網(wǎng)頁(yè)xxx.php是gb2312的編碼,存進(jìn)去的數(shù)據(jù)用php取出來是中文,用phpMyAdmin執(zhí)行select、update、dump都是中文,沒有亂碼問題。

從MySQL支持Unicode后,為了與時(shí)俱進(jìn),我們的web程序也開始考慮用UTF8了。其實(shí)UTF8也用了好幾年了,程序基本能跑,沒什么大問題,但是數(shù)據(jù)倒換的時(shí)候,總是遇到不爽的事情。

【問題現(xiàn)象】

網(wǎng)頁(yè)xxx.php用EditPlus另存為UTF8格式,MySQL在my.ini里設(shè)置default-character-set=utf8,建表時(shí)加了CREATE TABLE `xxx ` (myname varchar(255)) ENGINE=MyISAM DEFAULT CHARSET=utf8,用xxx.php執(zhí)行insert/update/select出來的都是中文,貌似沒問題,但是用phpMyAdmin看select是亂碼,用第三方工具軟件(如SQLyog)看select也是亂碼,mysqldump也是亂碼,很不爽。當(dāng)然,如果你建表的時(shí)候,選擇了binary/varbinary/blob類型,不會(huì)發(fā)現(xiàn)亂碼,因?yàn)橹付ǖ氖嵌M(jìn)制保存,MySQL保存數(shù)據(jù)時(shí)就沒有編碼的概念了。

【查找問題】

雖然在my.ini里設(shè)置default-character-set=utf8,但是執(zhí)行以下命令時(shí)有新發(fā)現(xiàn):

mysql> SHOW VARIABLES LIKE 'character%';

+----------------------------------------+-------------------------

| Variable_name            | Value

+----------------------------------------+-------------------------

| character_set_client       | latin1

| character_set_connection   | latin1

| character_set_database    | utf8

| character_set_filesystem    | binary

| character_set_results       | latin1

| character_set_server       | utf8

| character_set_system      | utf8

| character_sets_dir         | D:\mysql\share\charsets\

+----------------------------------------+-------------------------

8 rows in set (0.00 sec)

 

mysql> SHOW VARIABLES LIKE 'collation_%';

+---------------------------------------+------------------

| Variable_name           | Value           

+---------------------------------------+------------------

| collation_connection     | latin1_swedish_ci

| collation_database       | utf8_general_ci 

| collation_server         | utf8_general_ci 

+--------------------------------------+------------------

3 rows in set (0.00 sec)

發(fā)現(xiàn)Value列里面不全是utf8,仍然有部分是latin1,比如其中的client和connection。那網(wǎng)頁(yè)xxx.php的工作過程就是這樣的啦:從xxx.php頁(yè)面上輸入漢字,因?yàn)閤xx.php是UTF8編碼的,所以xxx.php以UTF8格式轉(zhuǎn)換輸入的漢字,然后以UTF8提交給mysql,但是mysql的client和connection都是latin1的,而表是UTF8的,所以mysql存儲(chǔ)時(shí),先將xxx.php提交的漢字,轉(zhuǎn)成latin1的格式,再轉(zhuǎn)成UTF8字符格式存在表中。如果此時(shí)我們用第三方軟件或者phpMyAdmin去select查看此表,而表中存儲(chǔ)的數(shù)據(jù)是被latin1過的UTF8字符,出來的時(shí)候是以UTF8格式取的,當(dāng)然看起來時(shí)亂碼了。解決方法就是讓所有過程都是UTF8的就可以了。

【解決問題】

1、從my.ini下手

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

[mysqld]

default-character-set=utf8

以上3個(gè)section都要加default-character-set=utf8,平時(shí)我們可能只加了mysqld一項(xiàng)。

然后重啟mysql,執(zhí)行

mysql> SHOW VARIABLES LIKE 'character%';

mysql> SHOW VARIABLES LIKE 'collation_%';

確保所有的Value項(xiàng)都是utf8即可。

2、建表時(shí)加utf8,表字段的Collation可加可不加,不加時(shí)默認(rèn)是utf8_general_ci了。

CREATE TABLE `tablename4` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`varchar1` varchar(255) DEFAULT NULL,

`varbinary1` varbinary(255) DEFAULT NULL,

PRIMARY KEY (`id`)

)  ENGINE=MyISAM  DEFAULT CHARSET=utf8

 

3、網(wǎng)頁(yè)xxx.php保存時(shí)選擇utf8編碼,頁(yè)頭最好加上

header('conten-type:text/html;charset=utf-8');

在執(zhí)行CRUD操作前先執(zhí)行一下

mysql_query("set names utf8");

測(cè)試代碼xxx.php如下:

<?php

header('conten-type:text/html;charset=utf-8');

mysql_connect("localhost", "root", "password") or die("Could not connect: " . mysql_error());

mysql_select_db("test");

mysql_query("set names utf8");

$str = "CHN 軟件開發(fā)有限公司,JPN ソフトウェア開発株式會(huì)社,KOR 소프트웨어 개발 유한 공사,RUS Суд программного обеспечения".time();

$sql = "insert into tablename4 (varchar1, varbinary1 ) values ('".$str."','".$str."')";

echo $sql."<hr>";

mysql_query($sql);

 

$result = mysql_query("SELECT id, varchar1 ,varbinary1 FROM tablename4");

while ($row = mysql_fetch_array($result, MYSQL_BOTH)) {

printf ("ID: %s , varchar1: %s, varbinary1: %s<br>", $row[0], $row["varchar1"], $row["varbinary1"]);

}

 

mysql_free_result($result);

?>

如此設(shè)置之后,無論是在php頁(yè)面插入任何utf8字符,在php頁(yè)面里取出來的,在phpMyAdmin里取出來的,在mysql的第三方客戶端軟件里取出來的,都是一樣的漢字了,不會(huì)再發(fā)現(xiàn)亂碼,mysqldump出來的也是漢字。OK,問題解決。

【另】在中文windows系統(tǒng)下,在cmd.exe里運(yùn)行mysql.exe字符終端,不能使用上面的規(guī)則,因?yàn)槟J(rèn)情況下,中文windows系統(tǒng)cmd.exe里的代碼頁(yè)是cp936即GBK,不能顯示全部UTF8字符,所以在字符終端里看到亂碼是正?,F(xiàn)象,不要奇怪,這個(gè)問題在類Unix系統(tǒng)的shell終端里可以解決的。

相關(guān)文章

  • MySQL中的聚簇索引、非聚簇索引、聯(lián)合索引和唯一索引詳細(xì)介紹

    MySQL中的聚簇索引、非聚簇索引、聯(lián)合索引和唯一索引詳細(xì)介紹

    本文主要介紹了MySQL的索引類型,根據(jù)索引的存儲(chǔ)方式來劃分,索引可以分為聚簇索引和非聚簇索引。聚簇索引的特點(diǎn)是葉子節(jié)點(diǎn)包含了完整的記錄行,而非聚簇索引的葉子節(jié)點(diǎn)只有所以字段和主鍵ID,感興趣的同學(xué)可以閱讀本文
    2023-04-04
  • win10免安裝版本的MySQL安裝配置教程

    win10免安裝版本的MySQL安裝配置教程

    這篇文章主要為大家詳細(xì)介紹了win10免安裝版本的MySQL的下載安裝和配置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 詳解MySQL聚合函數(shù)

    詳解MySQL聚合函數(shù)

    在 MySQL 中,聚合函數(shù)是用于計(jì)算多行數(shù)據(jù)的統(tǒng)計(jì)信息的函數(shù),例如總和、平均值、最大值、最小值和行數(shù)等。將多行數(shù)據(jù)聚合成單個(gè)結(jié)果,這是聚合函數(shù)得名的由來。本文將詳細(xì)介紹MySQL的聚合函數(shù),感興趣的小伙伴可以參考一下
    2023-04-04
  • MySQL常用登錄命令小結(jié)

    MySQL常用登錄命令小結(jié)

    本文主要介紹了MySQL常用登錄命令小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • MyCat環(huán)境搭建詳細(xì)教程

    MyCat環(huán)境搭建詳細(xì)教程

    這篇文章主要介紹了MyCat環(huán)境搭建詳細(xì)教程的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • mysql 存儲(chǔ)過程的問題

    mysql 存儲(chǔ)過程的問題

    最近我接觸了一本php 與 mysql,老外寫的一本書,書中有個(gè)tshirtshop網(wǎng)店代碼,其中操作數(shù)據(jù)庫(kù)的大多用的是mysql存儲(chǔ)過程
    2009-06-06
  • mysql查詢連續(xù)記錄方式

    mysql查詢連續(xù)記錄方式

    這篇文章主要介紹了mysql查詢連續(xù)記錄方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 教你使用VS?Code的MySQL擴(kuò)展管理數(shù)據(jù)庫(kù)的方法

    教你使用VS?Code的MySQL擴(kuò)展管理數(shù)據(jù)庫(kù)的方法

    這篇文章主要介紹了使用VS?Code的MySQL擴(kuò)展管理數(shù)據(jù)庫(kù),在本文告訴你如何用VS?Code的擴(kuò)展程序管理MySQL數(shù)據(jù)庫(kù),包括連接到MySQL、新建數(shù)據(jù)庫(kù)和表、修改字段定義、簡(jiǎn)單的查詢方法以及導(dǎo)入導(dǎo)出,需要的朋友可以參考下
    2022-01-01
  • 最新評(píng)論