mysql+记录的最大长度_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;

02259ed6c4e5a02211294f43788bde65.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;

9e0eb70a8fb22d93dc75316b85b31914.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;

23c3e5e1d95dbb03996250bc408a1769.png

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

21845 * 3 + 2 = 65537 > 65535

32767 * 2 + 2 = 65536 > 65535

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

todo:为什么多分配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;

248bf442344805429b1c46e77c22b02e.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;

c441188a8463ba7df571af533c035da7.png

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值