为什么 MySQL 引入 utf8mb4 数据类型?
时间:2024-11-19 17:22:10 173浏览 收藏
一分耕耘,一分收获!既然打开了这篇文章《为什么 MySQL 引入 utf8mb4 数据类型?》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!
MySQL 中 utf8mb4 的存储性质
在知乎的讨论中,有人提出 MySQL 引入 utf8mb4 数据类型的原因。本文将探讨 utf8mb4 的存储特性,以回答此问题。
utf8mb3 与 utf8mb4 的存储
MySQL 中原本的 utf8mb3 存储字符集最多三个字节一个字符,而 utf8mb4 支持四个字节的存储。
在之前,由于 MyISAM 存储引擎是默认引擎,其具有静态表格特性,使得 utf8mb3 的存储长度固定为最长三个字节。然而,在 InnoDB 成为默认引擎后,此特性不再适用。因此,在所有引擎中,utf8mb4 的存储长度都是可变的。
BMP 字符的存储
在 Unicode 中,BMP(基本多语言平面)包含了绝大多数常见语言的常见字符。对于 BMP 字符,utf8mb3 和 utf8mb4 具有相同的存储特性,长度为一到三个字节。这意味着在存储 BMP 字符时,utf8mb4 并不会占据额外的存储空间。
补充字符的存储
除了 BMP 字符之外,Unicode 还包含一些补充字符,这些字符位于 BMP 之外。utf8mb3 无法存储补充字符,而 utf8mb4 则可以。当将 utf8mb3 列转换为 utf8mb4 列时,这些补充字符不会被转换,因为 utf8mb3 中原本就不存在这些字符。
因此,utf8mb4 的存储长度取决于存储的字符集。对于 BMP 字符,它与 utf8mb3 长度相同。对于补充字符,它则需要四个字节的存储空间。
以上就是《为什么 MySQL 引入 utf8mb4 数据类型?》的详细内容,更多关于的资料请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
445 收藏
-
184 收藏
-
237 收藏
-
210 收藏
-
192 收藏
-
364 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习