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

深入Mysql字符集設(shè)置 圖文版

 更新時間:2012年09月04日 23:30:30   作者:  
在mysql客戶端與mysql服務(wù)端之間,存在著一個字符集轉(zhuǎn)換器

mysql客戶端與mysql服務(wù)端之間,存在著一個字符集轉(zhuǎn)換器。

character_set_client          =>gbk:轉(zhuǎn)換器就知道客戶端發(fā)送過來的是gbk格式的編碼

character_set_connection=>gbk:將客戶端傳送過來的數(shù)據(jù)轉(zhuǎn)換成gbk格式

character_set_results        =>gbk:

注:以上三個字符集可以使用set names gbk來統(tǒng)一進行設(shè)置

例子:

create table test(

name varchar(64) NOT NULL

)charset utf8;#這里的utf8表示服務(wù)器端的字符編碼

 

首先,往數(shù)據(jù)表test中插入一條數(shù)據(jù)

inert into test values('測試');

則,數(shù)據(jù)“測試”在數(shù)據(jù)庫中是以“utf8”格式保存的

過程:

 

首先,通過mysql客戶端,將數(shù)據(jù)發(fā)送給Mysql服務(wù)器,經(jīng)過字符集轉(zhuǎn)換器的時候,由于character_set_connection 值為gbk,所以會將客戶端發(fā)送過來的數(shù)據(jù)轉(zhuǎn)為gbk格式,緊接著,字符集轉(zhuǎn)換器將數(shù)據(jù)要傳送給服務(wù)器的時候,發(fā)現(xiàn)服務(wù)器是以utf8保存數(shù)據(jù)的,所以,在其內(nèi)部會自動將數(shù)據(jù)由gbk轉(zhuǎn)換成utf8格式

什么時候會出現(xiàn)亂碼?

    客戶端的數(shù)據(jù)格式與聲明的 character_set_client不符

        通過 header('Content-type:text/html;charset=utf8');將客戶端的數(shù)據(jù)轉(zhuǎn)成utf8格式的,在數(shù)據(jù)經(jīng)過“字符集轉(zhuǎn)換器”的時候,由于character_set_client=gbk,而character_set_connection也等于gbk,所以從客戶端傳送過來的數(shù)據(jù)(其實是utf8格式)并不會被轉(zhuǎn)換格式。

        但是,字符集轉(zhuǎn)換器在講數(shù)據(jù)發(fā)送給服務(wù)器的時候,發(fā)現(xiàn)服務(wù)器要的格式是utf8,所以會將當(dāng)前數(shù)          據(jù)當(dāng)做gbk格式來處理,從而轉(zhuǎn)成utf8(但是,這一步其實已經(jīng)錯了。。。)。

    2.  result與客戶端頁面不符合的時候        

 將返回結(jié)果的格式設(shè)置為utf8,但是客戶端接受的格式為gbk,因此會出現(xiàn)亂碼

通過show character set 語法,可以顯示所有可用的字符集

latin字符集

注意:Maxlen列顯示用于存儲一個字符的最大的字節(jié)數(shù)目。

utf8字符集

 

gbk字符集

什么時候會丟失數(shù)據(jù)?

對比以上三幅圖可以知道,每種字符集中,用于存儲一個字符的最大的字節(jié)數(shù)目都不同,utf8最大,latin最小。所以在經(jīng)過字符集轉(zhuǎn)換器的時候,如果處理不當(dāng),會造成數(shù)據(jù)丟失,而且是無法挽回的。

比如:

character_set_connection的值改為lantin的時候

從客戶端發(fā)送過來的gbk數(shù)據(jù),會被轉(zhuǎn)成lantin1格式,因為gbk格式的數(shù)據(jù)占用的字符數(shù)較多,從而會造成數(shù)據(jù)丟失

總結(jié):

character_set_client和character_set_results 一般情況下要一致,因為一個表示客戶端發(fā)送的數(shù)據(jù)格式,另一個表示客戶端接受的數(shù)據(jù)格式為了避免造成數(shù)據(jù)丟失,需讓 character_set_connection的字符編碼 大于 character_set_client的字符編碼

相關(guān)文章

  • SQL實現(xiàn)Excel的10個常用功能的示例詳解

    SQL實現(xiàn)Excel的10個常用功能的示例詳解

    SQL,數(shù)據(jù)分析崗的必備技能,你可以不懂Python,R,不懂可視化,不懂機器學(xué)習(xí)。但SQL,你必須懂。本文為大家總結(jié)了SQL實現(xiàn)Excel的10個常用功能的示例代碼,感興趣的可以了解一下
    2022-07-07
  • InnoDB 類型MySql恢復(fù)表結(jié)構(gòu)與數(shù)據(jù)

    InnoDB 類型MySql恢復(fù)表結(jié)構(gòu)與數(shù)據(jù)

    MySQL中.frm文件:保存了每個表的元數(shù)據(jù),包括表結(jié)構(gòu)的定義等,該文件與數(shù)據(jù)庫引擎無關(guān)。MySQL中.ibd文件:InnoDB引擎開啟了獨立表空間(my.ini中配置innodb_file_per_table = 1)產(chǎn)生的存放該表的數(shù)據(jù)和索引的文件。
    2018-01-01
  • Mysql Explain 詳細介紹

    Mysql Explain 詳細介紹

    這篇文章主要介紹了Mysql Explain 詳細介紹的相關(guān)資料,這里對Mysql Explain 的語法,屬性,以及如何使用,做了全面介紹,需要的朋友可以參考下
    2016-11-11
  • mysql 8.0.17 解壓版安裝配置方法圖文教程

    mysql 8.0.17 解壓版安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.17 解壓版安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • php連接MySQL的兩種方式對比

    php連接MySQL的兩種方式對比

    這篇文章主要介紹了php連接MySQL的兩種方式對比,一種是原生的鏈接方式另外一種是PDO方式,附上示例,推薦給大家,有需要的小伙伴可以參考下
    2015-04-04
  • MySQL如何利用DCL管理用戶和控制權(quán)限

    MySQL如何利用DCL管理用戶和控制權(quán)限

    這篇文章主要介紹了MySQL如何利用DCL管理用戶和控制權(quán)限,幫助大家更好的理解和學(xué)習(xí)MySQL的使用,感興趣的朋友可以了解下
    2020-11-11
  • 超詳細的mysql圖文安裝教程

    超詳細的mysql圖文安裝教程

    這篇文章主要為大家分享了一份超詳細的mysql圖文安裝教程,安裝步驟有詳細的說明,,需要的朋友可以參考下
    2016-05-05
  • MySQL常用命令大全腳本之家總結(jié)

    MySQL常用命令大全腳本之家總結(jié)

    這篇文章主要介紹了MySQL常用命令,總結(jié)了經(jīng)常使用的MySQL命令,需要的朋友可以參考下
    2014-02-02
  • MySQL字符串函數(shù)詳解(推薦)

    MySQL字符串函數(shù)詳解(推薦)

    下面小編就為大家?guī)硪黄狹ySQL字符串函數(shù)詳解(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • MySQL實戰(zhàn)教程之Join語句執(zhí)行流程

    MySQL實戰(zhàn)教程之Join語句執(zhí)行流程

    這篇文章主要介紹了MySQL Join語句執(zhí)行流程,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03

最新評論