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

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

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

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

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

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

character_set_results        =>gbk:

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

例子:

create table test(

name varchar(64) NOT NULL

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

 

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

inert into test values('測(cè)試');

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

過程:

 

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

什么時(shí)候會(huì)出現(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)換器”的時(shí)候,由于character_set_client=gbk,而character_set_connection也等于gbk,所以從客戶端傳送過來的數(shù)據(jù)(其實(shí)是utf8格式)并不會(huì)被轉(zhuǎn)換格式。

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

    2.  result與客戶端頁面不符合的時(shí)候        

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

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

latin字符集

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

utf8字符集

 

gbk字符集

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

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

比如:

character_set_connection的值改為lantin的時(shí)候

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

總結(jié):

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

相關(guān)文章

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

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

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

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

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

    Mysql Explain 詳細(xì)介紹

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

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

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

    php連接MySQL的兩種方式對(duì)比

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

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

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

    超詳細(xì)的mysql圖文安裝教程

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

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

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

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

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

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

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

最新評(píng)論