MySQL中的''、' '和 NULL在Innodb存储的区别

52次阅读
没有评论

共计 1611 个字符,预计需要花费 5 分钟才能阅读完成。

这篇文章主要介绍“MySQL 中的、和 NULL 在 Innodb 存储的区别”,在日常操作中,相信很多人在 MySQL 中的、和 NULL 在 Innodb 存储的区别问题上存在疑惑,丸趣 TV 小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL 中的、和 NULL 在 Innodb 存储的区别”的疑惑有所帮助!接下来,请跟着丸趣 TV 小编一起来学习吧!

一、测试环境

mysql  create table testn(a varchar(20),b varchar(20));
Query OK, 0 rows affected (0.43 sec)
mysql  insert into testn values( , gaopeng 
Query OK, 1 row affected (0.08 sec)
mysql  insert into testn values(   , gaopeng 
Query OK, 1 row affected (0.12 sec)
mysql  insert into testn values(NULL, gaopeng 
Query OK, 1 row affected (0.08 sec)
mysql  commit;
Query OK, 0 rows affected (0.00 sec)

我们看到包含了 3 行,包含了 3 种情况,下面我们分别分析。

二、解析

第一行 insert into testn values(‘’,’gaopeng’);

原始存储如下:

070000000010002200000014061c000000002fe5bb0000016e011067616f70656e67

07 : 第 2 个字段可变长度 7

00 : 第 1 个字段可变长度 0

00 :NULL 位图 没有 NULL 字段

0000100022:5 字节固定

00000014061c ROWID

000000002fe5 TRX ID

bb0000016e0110 ROLL PTR

:第一个字段没有存储 字符’’

67616f70656e67 : 第二个字段‘gaopeng’

第二行:insert into testn values(‘‘,’gaopeng’);

原始存储如下:

070100000018002200000014061d000000002fe6bc0000017901102067616f70656e67

07 : 第 2 个字段可变长度 7

01 : 第 1 个字段可变长度 1

00 :NULL 位图 没有 NULL 字段

0000180022:5 字节固定

00000014061d ROWID

000000002fe6 TRX ID

bc000001790110 ROLL PTR

20:空字符’‘

67616f70656e67 : 第二个字段‘gaopeng’

第三行:insert into testn values(NULL,’gaopeng’);

原始存储如下:

0701000020ffac00000014061e000000002febbf0000017c011067616f70656e67

07:第 2 个字段可变长度 7

01:NULL 位图为为 00000001 表示第一个字段为 NULL

000020ffac:5 字节固定

00000014061e ROWID

000000002feb TRX ID

bf0000017c0110 ROLL PTR

:第一个字段 NULL

67616f70656e67:第二个字段‘gaopeng’

三、总结

‘’不做存储,但是会记录可变长度的长度为 0,NULL 位图本位为 0。

NULL 不做实际存储,也不会记录可变长度,但是 NULL 位图本位为 1。

‘‘做存储为 0X20,记录可变长度为 01,NULL 位图本位为 0。

到此,关于“MySQL 中的、和 NULL 在 Innodb 存储的区别”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注丸趣 TV 网站,丸趣 TV 小编会继续努力为大家带来更多实用的文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-28发表,共计1611字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)