日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別

瀏覽:380日期:2023-02-18 16:43:14
目錄
  • 一、如何設(shè)置utf8mb4
  • 二、問題
    • 1、為什么存儲(chǔ)的時(shí)候要區(qū)分utf8和utf8mb4
    • 2、為什么讀取的時(shí)候要區(qū)分utf8和utf8mb4

一、如何設(shè)置utf8mb4

mysql中針對(duì)字符串類型,在設(shè)置charset的時(shí)候可以精確到字段。

如果只將某個(gè)字段設(shè)置utf8mb4,那么其他字段不會(huì)受影響。

如果針對(duì)表來設(shè)置,那么已經(jīng)存在的字段依然是utf8,并且會(huì)多出utf8的標(biāo)記,之后所創(chuàng)建的字段才會(huì)是utf8mb4

如果針對(duì)庫(kù)來設(shè)置,那么已經(jīng)存在的表依然是utf8,之后所創(chuàng)建的表才會(huì)是utf8mb4

除此之外呢,我們?cè)谶B接數(shù)據(jù)庫(kù)的時(shí)候,也要指明charset=utf8mb4,否則的話,此連接無法向utf8mb4的字段寫入數(shù)據(jù),并且讀取的時(shí)候是亂碼。

在使用 navicat 的時(shí)候,發(fā)現(xiàn)沒有地方設(shè)置連接的字符編碼,他會(huì)自動(dòng)掃面你的數(shù)據(jù)庫(kù),表,字段的編碼,來自動(dòng)設(shè)置一個(gè)合適的編碼,當(dāng)然,這也跟 navicat 版本有關(guān),高版本才行,我的低版本就不行,如果你發(fā)現(xiàn)你的 navicat 無法顯示表情,只能看到問好,那么可以通過show variables like '%char%'查看一下。

我還遇到一個(gè)情況,我的 navicat 沒法自動(dòng)設(shè)置 utf8mb4,因此,在 utf8 的情況下,我將線上的表情同步到了我本地,這使得我在后面即使設(shè)置了 utf8mb4 的情況下也看不到表情,這是因?yàn)槲以?utf8 的時(shí)候同步過來的數(shù)據(jù)被破壞了,字符集不兼容,所以需要先設(shè)置好字符編碼再拉取一次數(shù)據(jù)。

二、問題

1、為什么存儲(chǔ)的時(shí)候要區(qū)分utf8和utf8mb4

按理說,不管我存進(jìn)去的是單字節(jié)還是多字節(jié),本質(zhì)都是二進(jìn)制,我寫入什么你就存什么不就好了,干嘛還要有限制。這是因?yàn)椋琈ysql對(duì)每個(gè)字段都定義了長(zhǎng)度,比如varchar(10)表示10個(gè)字符,而不是字節(jié),所以當(dāng)存入數(shù)據(jù)的時(shí)候,mysql是做了解析的,這樣才能知道字符串里有幾個(gè)字符;當(dāng)面對(duì)4字節(jié)字符的時(shí)候,mysql依然會(huì)以3字節(jié)的編碼規(guī)則來解析,顯然會(huì)解析出錯(cuò)的,因此就不讓寫入。

MySQL在5.5.3之后增加了這個(gè)utf8mb4的編碼,mb4就是most bytes 4的意思,專門用來兼容四字節(jié)的unicode。好在 utf8mb4 是 utf8 的超集,除了將編碼改為 utf8mb4 外不需要做其他轉(zhuǎn)換。當(dāng)然,為了節(jié)省空間,一般情況下使用 utf8 也就夠了。

utf8 是 Mysql 中的一種字符集,只支持最長(zhǎng)三個(gè)字節(jié)的 UTF-8 字符,可能是因?yàn)?Mysql 剛開始開發(fā)那會(huì),Unicode 還沒有4字節(jié)的字符。至于后續(xù)的版本為什么不對(duì) 4 字節(jié)長(zhǎng)度的 UTF-8 字符提供支持,應(yīng)該是為了向后兼容性的考慮,還有就是4字節(jié)字符確實(shí)很少用到。

2、為什么讀取的時(shí)候要區(qū)分utf8和utf8mb4

按理說,我讀取的都是二進(jìn)制,不管是三字節(jié)還是四字節(jié),我自己來展示,為什么在讀取 utf8mb4 字段的時(shí)候,我使用 utf8 的連接得到的是亂碼,使用 utf8mb4 連接得到的是正常的。實(shí)際上我的電腦是能展示四字節(jié)字符的。

因?yàn)閙ysql有個(gè)連接器組件,它處于客戶端和服務(wù)器之間,用于字符集的轉(zhuǎn)換。

現(xiàn)在有一個(gè)字段name,為了兼容emoj表情,字段設(shè)置為utf8mb4,在寫入的時(shí)候數(shù)據(jù)庫(kù)連接設(shè)置了charset=utf8mb4,因此可以正常寫入;在讀取的時(shí)候數(shù)據(jù)庫(kù)連接設(shè)置charset=utf8,于是讀出來展示的時(shí)候是亂碼,如果改成charset=utf8mb4,讀出來就能正常展示,那就是說,utf8的連接讀到的結(jié)果并不是真實(shí)的數(shù)據(jù),而是經(jīng)過了連接器的轉(zhuǎn)換,它將utf8mb4轉(zhuǎn)換成了utf8,四字節(jié)字符被轉(zhuǎn)換成了三字節(jié),自然就是亂碼。

那么,為什么要有這個(gè)轉(zhuǎn)碼的過程呢?

那是因?yàn)閙ysql支持很多的字符編碼。

mysql> show character set;+----------+-----------------------------+---------------------+--------+| Charset  | Description | Default collation   | Maxlen |+----------+-----------------------------+---------------------+--------+| big5     | Big5 Traditional Chinese    | big5_chinese_ci     |      2 || dec8     | DEC West European   | dec8_swedish_ci     |      1 || cp850    | DOS West European   | cp850_general_ci    |      1 || hp8      | HP West European    | hp8_english_ci      |      1 || koi8r    | KOI8-R Relcom Russian       | koi8r_general_ci    |      1 || latin1   | cp1252 West European| latin1_swedish_ci   |      1 || latin2   | ISO 8859-2 Central European | latin2_general_ci   |      1 || swe7     | 7bit Swedish| swe7_swedish_ci     |      1 || ascii    | US ASCII    | ascii_general_ci    |      1 || ujis     | EUC-JP Japanese     | ujis_japanese_ci    |      3 || sjis     | Shift-JIS Japanese  | sjis_japanese_ci    |      2 || hebrew   | ISO 8859-8 Hebrew   | hebrew_general_ci   |      1 || tis620   | TIS620 Thai | tis620_thai_ci      |      1 || euckr    | EUC-KR Korean       | euckr_korean_ci     |      2 || koi8u    | KOI8-U Ukrainian    | koi8u_general_ci    |      1 || gb2312   | GB2312 Simplified Chinese   | gb2312_chinese_ci   |      2 || greek    | ISO 8859-7 Greek    | greek_general_ci    |      1 || cp1250   | Windows Central European    | cp1250_general_ci   |      1 || gbk      | GBK Simplified Chinese      | gbk_chinese_ci      |      2 || latin5   | ISO 8859-9 Turkish  | latin5_turkish_ci   |      1 || armscii8 | ARMSCII-8 Armenian  | armscii8_general_ci |      1 || utf8     | UTF-8 Unicode       | utf8_general_ci     |      3 || ucs2     | UCS-2 Unicode       | ucs2_general_ci     |      2 || cp866    | DOS Russian | cp866_general_ci    |      1 || keybcs2  | DOS Kamenicky Czech-Slovak  | keybcs2_general_ci  |      1 || macce    | Mac Central European| macce_general_ci    |      1 || macroman | Mac West European   | macroman_general_ci |      1 || cp852    | DOS Central European| cp852_general_ci    |      1 || latin7   | ISO 8859-13 Baltic  | latin7_general_ci   |      1 || utf8mb4  | UTF-8 Unicode       | utf8mb4_general_ci  |      4 || cp1251   | Windows Cyrillic    | cp1251_general_ci   |      1 || utf16    | UTF-16 Unicode      | utf16_general_ci    |      4 || utf16le  | UTF-16LE Unicode    | utf16le_general_ci  |      4 || cp1256   | Windows Arabic      | cp1256_general_ci   |      1 || cp1257   | Windows Baltic      | cp1257_general_ci   |      1 || utf32    | UTF-32 Unicode      | utf32_general_ci    |      4 || binary   | Binary pseudo charset       | binary      |      1 || geostd8  | GEOSTD8 Georgian    | geostd8_general_ci  |      1 || cp932    | SJIS for Windows Japanese   | cp932_japanese_ci   |      2 || eucjpms  | UJIS for Windows Japanese   | eucjpms_japanese_ci |      3 |+----------+-----------------------------+---------------------+--------+40 rows in set

collation為排序規(guī)則,Maxlen為最大字節(jié)數(shù)。

不同的編碼規(guī)則,會(huì)得到不同的二進(jìn)制數(shù),因此正確的編碼轉(zhuǎn)換是必要的。

查看當(dāng)前的編碼

mysql> show variables like "%char%";+--------------------------+--------+| Variable_name    | Value  |+--------------------------+--------+| character_set_client     | utf8   || character_set_connection | utf8   || character_set_database   | utf8   || character_set_filesystem | binary || character_set_results    | utf8   || character_set_server     | utf8   || character_set_system     | utf8   || character_sets_dir       ||+--------------------------+--------+

設(shè)置當(dāng)前連接的編碼,只針對(duì)此連接有效

mysql -h xxxxxx.mysql.rds.aliyuncs.com -u xxxxxx -p xxxxxxmysql> set names gbk;mysql> show variables like "%char%";+--------------------------+--------+| Variable_name    | Value  |+--------------------------+--------+| character_set_client     | gbk    || character_set_connection | gbk    || character_set_database   | utf8   || character_set_filesystem | binary || character_set_results    | gbk    || character_set_server     | utf8   || character_set_system     | utf8   || character_sets_dir       ||+--------------------------+--------+

這個(gè)命令會(huì)同時(shí)修改character_set_client, character_set_connection, character_set_results

我們?cè)诮訑?shù)據(jù)庫(kù)的時(shí)候設(shè)置的charset=utf8在內(nèi)部就是調(diào)用的set names utf8

所以,代表客戶端的編碼有三個(gè),這三個(gè)編碼基本是一致的。其他的都是服務(wù)端的的編碼。

character_set_client 客戶端

character_set_connection 連接器

character_set_results 返回的結(jié)果集

既然是一樣的,為什么客戶端要搞三個(gè)配置呢,這就要從數(shù)據(jù)傳輸?shù)牧鞒躺蟻砜础?/p>

連接器:連接客戶端與服務(wù)端,進(jìn)行字符集的轉(zhuǎn)換。

連接器的工作流程:

請(qǐng)求

character_set_client --> character_set_connection -->character_set_server

響應(yīng)

character_set_server --> character_set_connection --> character_set_results

圖示

到此這篇關(guān)于mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別的文章就介紹到這了,更多相關(guān)mysql utf8與utf8mb4內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜臀久久99精品久久久画质超高清| 噜噜噜躁狠狠躁狠狠精品视频 | 久久免费影院| 日韩高清一区在线| 国产91在线精品| 一区免费在线| 日韩精品91亚洲二区在线观看| 国产精区一区二区| 美腿丝袜亚洲三区| 成人久久久久| 99成人在线视频| 中文字幕av一区二区三区四区| 蜜臀av在线播放一区二区三区| 日韩理论视频| 韩国女主播一区二区三区| 精品日韩视频| 亚洲三级在线| 精品99在线| 亚洲影视一区二区三区| 国产精品二区不卡| 好看的av在线不卡观看| 精品久久中文| 高清av一区| 国产精品国产一区| 日本在线成人| 欧产日产国产精品视频| 亚洲精品影视| 午夜欧美在线| 久久永久免费| 日韩高清在线不卡| 免费一级欧美在线观看视频 | 亚洲精品第一| 欧美精品羞羞答答| 国产欧美一区二区三区精品酒店 | 亚洲欧洲美洲国产香蕉| 麻豆中文一区二区| 在线精品视频一区| 国产一区清纯| 在线日韩视频| 欧美极品中文字幕| 日本一区免费网站| 国产视频一区免费看| 性欧美69xoxoxoxo| 久久久久久亚洲精品美女| 日韩精品成人在线观看| 亚洲精品看片| 蜜臀久久99精品久久久久宅男| 一本大道色婷婷在线| 成人在线视频区| 国产精品www.| 日本在线不卡视频一二三区| 国产精品呻吟| 伊人成人在线视频| 国产亚洲午夜| 午夜在线精品偷拍| 亚洲免费在线| 蜜臀精品久久久久久蜜臀 | 久久久久久久久成人| 老鸭窝亚洲一区二区三区| 一区二区小说| 天使萌一区二区三区免费观看| 99视频精品| 夜夜嗨网站十八久久| 亚洲激情另类| 视频在线观看一区| 久久激情五月激情| 精品福利久久久| 1000部精品久久久久久久久| 在线视频精品| 欧美自拍一区| 欧美日韩a区| 欧美一区二区三区久久精品| 国产精品久久久网站| 欧美极品一区二区三区| 日韩av在线中文字幕| 亚洲成人国产| 中文亚洲欧美| 中文不卡在线| 欧美日韩亚洲一区在线观看| 国产精品magnet| 国产超碰精品| 亚洲永久精品唐人导航网址| 国产精品主播| 精品一区免费| 国产欧美日韩一区二区三区在线| 久久精品理论片| 欧美日韩水蜜桃| 欧美日韩一区二区三区四区在线观看| 成人高清一区| 日韩毛片网站| 欧美1区2区3区| 麻豆中文一区二区| 国精品一区二区三区| 日韩国产欧美在线播放| 久久久久久婷| 日韩激情一二三区| 日本在线精品| 久久男人av| 久久xxxx| 91tv亚洲精品香蕉国产一区| 日韩高清成人在线| 蜜桃成人av| 精品一区二区三区视频在线播放| 丝袜国产日韩另类美女| 蜜桃视频在线观看一区| 国产精品国产一区| 欧美亚洲三级| 亚洲v在线看| 国产精品一级在线观看| 国产麻豆综合| 亚洲国产欧美日本视频| 日韩av不卡一区二区| 亚洲少妇诱惑| 美女网站一区| 欧美sm一区| 日本精品黄色| 国产经典一区| 国产精品视频一区二区三区综合| 快she精品国产999| 尤物tv在线精品| 午夜久久中文| 91综合视频| 麻豆精品久久| 国产一区二区三区视频在线| 欧美二区视频| 红桃视频亚洲| 亚洲成人日韩| 日韩午夜在线| 一二三区精品| 欧美精品影院| 91成人小视频| 国产美女撒尿一区二区| 国产精品午夜av| 美女国产一区二区三区| 精品99在线| 久久国产电影| 在线观看一区| 日韩精品一二三区| 在线综合亚洲| 日韩精品免费观看视频| 国产剧情一区| 日韩国产网站| 噜噜噜躁狠狠躁狠狠精品视频| 中文无码久久精品| 麻豆成人91精品二区三区| 国内自拍视频一区二区三区| 夜夜嗨av一区二区三区网站四季av| 毛片在线网站| 国内精品福利| 蜜臀久久久久久久| 日韩av电影一区| 精品三级久久久| 欧美黄色一区二区| bbw在线视频| 蜜桃久久av| 久久精品三级| 久久亚洲国产精品一区二区| 国产精品一区二区中文字幕| 韩国久久久久久| 免费看的黄色欧美网站| 精品一二三区| 久久成人国产| 麻豆国产91在线播放| 麻豆精品蜜桃| 国产日韩视频| 欧美大黑bbbbbbbbb在线| 欧美日韩中出| 久久国产电影| 日本精品在线播放| 久久精品国产99久久| 国产精品调教| 久久国产精品久久w女人spa| 岛国av在线网站| 91精品尤物| 亚洲免费播放| 日韩视频网站在线观看| 国产精品嫩模av在线| 一区二区三区四区日韩| 欧美日韩在线观看视频小说| 美女av一区| 国产精品观看| 日韩中文字幕| 亚洲视频二区| 国产一区二区三区不卡av| 日本一区二区三区视频在线看| 欧美不卡视频| 久久久久久久久久久9不雅视频| 国产精品magnet| 国产精品流白浆在线观看| 日韩精品导航| 欧美日本一区| 国产欧美在线观看免费| 欧美一区自拍| 国产精品观看| 麻豆国产91在线播放| 成人国产精选| 国产 日韩 欧美 综合 一区| 另类小说一区二区三区| 91成人精品在线| 国产精品a久久久久|