女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

MySQL中utf8和utf8mb4有什么區別

汽車玩家 ? 來源:IT生涯 ? 作者:IT生涯 ? 2020-04-12 19:21 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、簡介

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

二、內容描述

那上面說了既然utf8能夠存下大部分中文漢字,那為什么還要使用utf8mb4呢? 原來mysql支持的 utf8 編碼最大字符長度為 3 字節,如果遇到 4 字節的寬字符就會插入異常了。三個字節的 UTF-8 最大能編碼的 Unicode 字符是 0xffff,也就是 Unicode 中的基本多文種平面(BMP)。也就是說,任何不在基本多文本平面的 Unicode字符,都無法使用 Mysql 的 utf8 字符集存儲。包括 Emoji 表情(Emoji是一種特殊的 Unicode 編碼,常見于 iosandroid 手機上),和很多不常用的漢字,以及任何新增的 Unicode 字符等等(utf8的缺點)。

通常,計算機在存儲字符時,會根據不同類型的字符以及編碼方式分配存儲空間。例如以下幾種編碼方式;

①ASCII編碼中,一個英文字母(不分大小寫)占用一個字節的空間,一個中文漢字占用兩個字節的空間。一個二進制的數字序列,在計算機中作為一個數字單元存儲時,一般為8位二進制數,換算為十進制。最小值0,最大值255。

②UTF-8編碼中,一個英文字符占用一個字節的存儲空間,一個中文(含繁體)占用三個字節的存儲空間。

③Unicode編碼中,一個英文占用兩個字節的存儲空間,一個中文(含繁體)占用兩個字節的存儲空間。

④UTF-16編碼中,一個英文字母字符或一個漢字字符存儲都需要占用2個字節的存儲空間(Unicode擴展區的一些漢字存儲需要4個字節)。

⑤UTF-32編碼中,世界上任何字符的存儲都需要占用4個字節的存儲空間。

既然utf8能兼容絕大部分的字符,為什么要擴展utf8mb4?

隨著互聯網的發展,產生了許多新類型的字符,例如emoji這種類型的符號,也就是我們通常在聊天時發的小黃臉表情,這種字符的出現不在基本多平面的Unicode字符之中,導致無法在MySQL中使用utf8存儲,MySQL于是對utf8字符進行了擴展,增加了utf8mb4這個編碼。

所以,設計數據庫時如果想要允許用戶使用特殊符號,最好使用utf8mb4編碼來存儲,使得數據庫有更好的兼容性,但是這樣設計會導致耗費更多的存儲空間。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • MySQL
    +關注

    關注

    1

    文章

    850

    瀏覽量

    27732
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    GD32與STM32什么區別

    電子發燒友網站提供《GD32與STM32什么區別.docx》資料免費下載
    發表于 04-03 17:27 ?0次下載

    DLPvideo模式與pattern模式什么區別

    你好,請問,在DLP相關文檔提到video模式與 pattern模式,請問這兩種模式什么區別
    發表于 03-03 08:32

    私有云和公有云什么區別

    私有云和公有云在多個方面存在顯著的區別,以下是具體的比較,主機推薦小編為您整理發布私有云和公有云什么區別
    的頭像 發表于 02-20 10:38 ?660次閱讀

    AIGC和AI什么區別

    AIGC是AI在內容生成領域的一個特定應用方向,AI的技術發展為AIGC提供了基礎和支撐。那么,AIGC和AI什么區別呢?下面,AI部落小編帶您詳細了解。
    的頭像 發表于 02-20 10:33 ?763次閱讀

    windows服務器備份mysql腳本

    一、linux備份 使用python腳本,要求python3和mysqldump #! /usr/bin/python36# -*- coding: utf-8 -*-import
    的頭像 發表于 01-02 09:14 ?351次閱讀

    ADS1256的SYSGCAL系統增益校準和SELFGCAL增益自動校準什么區別

    請問一個問題:ADS1256的SYSGCAL系統增益校準和SELFGCAL 增益自動校準什么區別?SELFCAL 偏移和增益自動校準又有何區別?SELFOCAL偏移自動校準又何
    發表于 12-13 12:22

    FCCSP與FCBGA都是倒裝有什么區別

    本文簡單介紹了倒裝芯片球柵陣列封裝與倒裝芯片級封裝的概念與區別。 FCCSP與FCBGA都是倒裝,怎么區分?什么區別
    的頭像 發表于 11-16 11:48 ?3934次閱讀
    FCCSP與FCBGA都是倒裝有<b class='flag-5'>什么區別</b>

    美國多IP服務器和美國多服務器什么區別

    美國多IP服務器和美國多服務器什么區別 美國多IP服務器和美國多服務器在概念、功能以及應用場景上存在明顯的區別。主機推薦小編為您整理發布美國多IP服務器和美國多服務器
    的頭像 發表于 11-11 10:22 ?644次閱讀

    RTOS與Linux到底什么區別

    很多做嵌入式開發的小伙伴都存在這樣的疑惑:RTOS與Linux到底什么區別
    的頭像 發表于 10-29 09:53 ?1196次閱讀

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-開發環境搭建之VScode的安裝及使用

    插件 Document This:快速注釋 ESLint:代碼檢查工具 DeviceTree:設備商語法 GBK to UTF8 for vscode:GBK轉UTF8插件 Vscode-icons
    發表于 10-09 15:44

    飛凌嵌入式ElfBoard ELF 1板卡-開發環境搭建之VScode的安裝及使用

    ESLint:代碼檢查工具DeviceTree:設備商語法GBK to UTF8 for vscode:GBK轉UTF8插件Vscode-icons:文件圖標擴展包安裝方法:安裝完成后,雙擊桌面
    發表于 09-30 09:40

    OPA227UA和OPA227UAG4和OPA227UAE4什么區別

    請問,OPA227UA 、OPA227UAG4 、OPA227UAE4這三種什么區別
    發表于 09-26 08:24

    請問TLC274BIDR和TLC274BIDRG4什么區別

    請問TLC274BIDR和TLC274BIDRG4這兩種什么區別?經過查證買的芯片都是正品,但有一個G4的后標,現在出問題的都是這個帶G4
    發表于 08-23 07:39

    IG902如何上傳數據到MQTT云平臺EMQX ?

    =utf8MB4; 1 rows in set(0.00sec) MySQL主題訂閱表 mqtt_sub 存儲設備的主題訂閱關系: DROPTABLEIFEXISTS`mqtt_sub
    發表于 07-25 07:09

    請問ESPTOUCH和AIRKISS什么區別

    請問ESPTOUCH和AIRKISS什么區別?謝謝!
    發表于 07-12 12:44