史上最简单的 MySQL 教程(八)「记录长度」

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 史上最简单的 MySQL 教程(八)「记录长度」

史上最简单的 MySQL 教程(八)「记录长度」

记录长度

MySQL 中规定:任何一条记录最长不超过 65535 个字节,这意味着varchar永远达不到理论最大值。

那么,varchar实际存储长度能达到多大呢?这由编码字符集决定。

下面,以varchar在UTF-8和GBK的情况为例,执行如下 SQL 语句,进行演示:

-- 求出 varchar 在 utf8 和 gbk 字符集下的实际最大值
create table my_utf8(
  name varchar(65535)
)charset utf8;
create table my_gbk(
  name varchar(65535)
)charset gbk;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FFrc97F6-1648097149251)(https://github.com/guobinhit/mysql-tutorial/blob/master/images/record-length/create-table-myutf8.png)]


观察上面的结果,发现咱们定义的字段name的长度超过限制啦,并且提示了其在utf8和gbk字符集下各自的最大值。那么,咱们修改 SQL 语句如下,并再次执行:

-- 求出 varchar 在 utf8 和 gbk 字符集下的实际最大值
create table my_utf8(
  name varchar(21845)
)charset utf8;
create table my_gbk(
  name varchar(32767)
)charset gbk;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DSywWSOK-1648097149253)(https://github.com/guobinhit/mysql-tutorial/blob/master/images/record-length/myutf8-mygbk.png)]


观察上面的执行结果,好吧,仍然在报错,为什么呢?观察如下 SQL 语句,并执行:

-- 求出 varchar 在 utf8 和 gbk 字符集下的实际最大值
create table my_utf8(
  name varchar(21844)  -- 21844 * 3 + 2 = 65534
)charset utf8;
create table my_gbk(
  name varchar(32766)  -- 32766 * 2 + 2 = 65534
)charset gbk;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gUfHYljo-1648097149254)(https://github.com/guobinhit/mysql-tutorial/blob/master/images/record-length/utf8-gbk.png)]


如上图所示,咱们已经创建成功啦!至于什么定义字段name的长度为21844和32766是由于:


21845 * 3 + 2 = 65537 > 65535

32767 * 2 + 2 = 65536 > 65535

因此,在提示的最大值的基础上各自减1. 至于,为什么还要加2,则是因为varchar为变长字符串,在其定义的时候,也就是说在分配存储空间的时候,都会自动多分配1到2个字节空间,因为咱们想要算最大的存储范围,所以加2.


在这里,细心的同学会发现一个问题,那就是:在咱们创建表my_utf8和my_gbk的时候,咱们仅用了65534个字节,还剩余一个字节。现在,如果咱们想要将65535个字节都用了,怎么办呢?好说,增加一个tinyint类型的字段即可:


-- 求出 varchar 在 utf8 和 gbk 字符集下的实际最大值
create table my_utf81(
  stuno tinyint,       -- 1
  name varchar(21844)  -- 21844 * 3 + 2 = 65534
)charset utf8;
create table my_gbk1(
  stuno tinyint,       -- 1
  name varchar(32766)  -- 32766 * 2 + 2 = 65534
)charset gbk;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mqVmLIch-1648097149255)(https://github.com/guobinhit/mysql-tutorial/blob/master/images/record-length/myutf81-mygbk1.png)]


观察上面的结果,呃,竟然又出错啦!为什么啊?65534 + 1 = 65535,并没有超出范围啊!其实吧,之所以会出现这样的问题,是因为:在 MySQL 的记录中,如果有任何一个字段允许为空,那么系统就会自动从整个记录中保留一个字节来存储null,若想释放null所占的字节,则必须保证所有字段都不允许为空。

-- 求出 varchar 在 utf8 和 gbk 字符集下的实际最大值
create table my_utf82(
  stuno tinyint not null,       -- 1
  name varchar(21844) not null  -- 21844 * 3 + 2 = 65534
)charset utf8;
create table my_gbk2(
  stuno tinyint not null,       -- 1
  name varchar(32766) not null  -- 32766 * 2 + 2 = 65534
)charset gbk;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YZVNkNeZ-1648097149255)(https://github.com/guobinhit/mysql-tutorial/blob/master/images/record-length/myutf82-mygbk2.png)]


如上图所示,咱们已经成功创建了表my_utf82和my_gbk2.


此外,在 MySQL 中,text文本字符串不占用记录长度,额外存储,但是text文本字符串也是属于记录的一部分,无论是在utf8还是在gbk字符集之中,其都占用记录中的10个字节长度,用来保存数据的地址以及长度。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4月前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
159 3
|
2月前
|
存储 SQL 关系型数据库
【入门级教程】MySQL:从零开始的数据库之旅
本教程面向零基础用户,采用通俗易懂的语言和丰富的示例,帮助你快速掌握MySQL的基础知识和操作技巧。内容涵盖SQL语言基础(SELECT、INSERT、UPDATE、DELETE等常用语句)、使用索引提高查询效率、存储过程等。适合学生、开发者及数据库爱好者。
46 0
【入门级教程】MySQL:从零开始的数据库之旅
|
2月前
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
4月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
4月前
|
关系型数据库 MySQL 网络安全
MySQL主从复制详细教程
配置MySQL的主从复制是一个细致的过程,需要仔细遵循上述步骤进行。一旦配置完成并运行正常,主从复制将大大提高数据库的可用性和读写性能。在操作过程中,务必保持谨慎,确保数据的一致性和安全性。
425 0
|
5月前
|
关系型数据库 MySQL Linux
Docker安装mysql详细教程, mysqld: Can‘t read dir of ‘/etc/mysql/conf.d/‘(报错已解决)
Docker安装mysql详细教程, mysqld: Can't read dir of '/etc/mysql/conf.d/' (Errcode: 2 - No such file or directory) 已解决
|
5月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
335 3
|
5月前
|
关系型数据库 MySQL 数据库
MySQL 保姆级教程(八):创建计算字段
MySQL 保姆级教程(八):创建计算字段
|
5月前
|
关系型数据库 MySQL
MySQL 保姆级教程(五):数据过滤
MySQL 保姆级教程(五):数据过滤
|
5月前
|
关系型数据库 MySQL
MySQL 保姆级教程(四):过滤数据
MySQL 保姆级教程(四):过滤数据