返回顶部
首页 > 资讯 > 数据库 >如何基于MySQL在磁盘上存储NULL值
  • 905
分享到

如何基于MySQL在磁盘上存储NULL值

2023-06-29 07:06:34 905人浏览 八月长安
摘要

小编给大家分享一下如何基于MySQL在磁盘上存储NULL值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 为何不能直接存个NULL?NULL值列表,一行数据里可

小编给大家分享一下如何基于MySQL在磁盘上存储NULL值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1 为何不能直接存个NULL?

NULL值列表,一行数据里可能有的字段值是NULL,比如nickname字段,允许为NULL,存储时,如果没赋值,这字段值就是NULL。
假设这个字段的NULL值在磁盘存储时,就是按“NULL”字符串存储的,是不是很浪费存储空间而且还奇怪?

2 到底怎么存储?

不通过字符串,而是通过二进制bit位存储,一行数据里假设有多个字段的值都是NULL,那么这多个字段的NULL,就会以bit位形式存放在NULL值列表。

如下表:

CREATE TABLE customer (  name VARCHAR(10) NOT NULL,  address VARCHAR(20), gender CHAR(1),  job VARCHAR(30),  school VARCHAR(50)) ROW_FORMAT=COMPACT;

有4个变长字段,还有个定长字段,name声明NOT NULL,其他4个字段都可能NULL
如下一行数据怎么存储在磁盘呢:

jack NULL m NULL xx_school

有俩字段都是NULL

3 一行数据的磁盘存储格式

思考上面那个表里的那行案例数据,在磁盘上如何存储呢,因为他有多个变长字段,还有多个字段允许为NULL。首先我们先回顾一下,一行数据在磁盘上的存储格式应该是下面这样的:

变长字段长度列表 NULL值列表 头信息 column1=value1 column2=value2 ... columnN=valueN

4个变长字段,逆序先放school字段的长度,再放job、address、name几个字段的值长度?
但要区分一个问题,若这变长字段值为NULL,就不用在变长字段长度列表里存放他的值长度,所以在上面那行数据,只有name和school两个变长字段有值,把他们的长度按照逆序放在变长字段长度列表即可:

0x09 0x04 NULL值列表 头信息 column1=value1 column2=value2 ... columnN=valueN

所有允许值为NULL的字段,不是说值就得是NULL,只要是允许为NULL的字段,每个字段都有个二进制bit位值:

  • bit值是1说明是NULL

  • bit值是0说明不是NULL

比如上面4个字段都允许为NULL,每个人都会有一个bit位,这一行数据的值是

jack NULL m NULL xx_school

其中2个字段是null,2个字段不是null,所以4个bit位应该是:1010
但实际放在NULL值列表时,按逆序放,所以NULL值列表里放的:0101,整体这一行数据如下:

0x09 0x04 0101 头信息 column1=value1 column2=value2 ... columnN=valueN

实际NULL值列表存放时,一般起码8个bit位的倍数,不足8个bit位就高位补0,所以实际存放如下:

0x09 0x04 00000101 头信息 column1=value1 column2=value2 ... columnN=valueN

4 如何读磁盘的一行数据?

磁盘数据存储格式:

0x09 0x04 00000101 头信息 column1=value1 column2=value2 ... columnN=valueN

先读:

  • 变长字段长度列表

就知道有几个变长字段

  • NULL值列表

哪些变长字段是NULL:

从变长字段长度列表中解析出不为NULL的变长字段的值长度,然后也知道哪些字段是NULL。根据这些信息,就能从实际的列值存储区域里,把你每个字段的值读取出来了。

  • 变长字段值,就按值长度读取,若为NULL,就知道他是个NULL,没有值存储

  • 定长字段,按定长长度读取

以上是“如何基于Mysql在磁盘上存储NULL值”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: 如何基于MySQL在磁盘上存储NULL值

本文链接: https://lsjlt.com/news/323198.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何基于MySQL在磁盘上存储NULL值
    小编给大家分享一下如何基于MySQL在磁盘上存储NULL值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 为何不能直接存个NULL?NULL值列表,一行数据里可...
    99+
    2023-06-29
  • 基于MySQL在磁盘上存储NULL值
    目录1 为何不能直接存个NULL?2 到底怎么存储?3 一行数据的磁盘存储格式4 如何读磁盘的一行数据?1 为何不能直接存个NULL? NULL值列表,一行数据里可能有的字段值是NU...
    99+
    2024-04-02
  • Linux系统如何查看磁盘储存
    Linux系统如何查看磁盘储存,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。下面是一个可供选择的,但并不全面的图形或命令行工具列表,这些工具用来检查Linux平台中已用和可用的...
    99+
    2023-06-28
  • 将mysql存储位置迁移到一块新磁盘上的方法
    小编给大家分享一下将mysql存储位置迁移到一块新磁盘上的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.准备一块新的磁盘...
    99+
    2024-04-02
  • MySQL 存储函数如何在使用表中的动态值时评估它是否获得 NULL 值?
    在这种情况下,当存储函数获取 NULL 值时,它将返回 NULL 作为结果。从下面的例子可以看出,学生‘Mohit’的记录中有一个NULL值。现在,当我们对此数据应用存储的函数“avg_marks”时,它将返回 NULL 作为结果。mysq...
    99+
    2023-10-22
  • 如何将Session值储存于SQL Server中
    如何将Session值储存于SQL Server中,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一般情况下,我们喜欢使用Ses...
    99+
    2024-04-02
  • 如何构建基于Ceph对象存储
    这篇文章主要介绍了如何构建基于Ceph对象存储,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。存储发展数据存储是人类永恒的话题和不断探索的主题绳结记事原始社会,文字未发明之前 ...
    99+
    2023-06-02
  • 如何解决overlay2存储驱动的磁盘配额问题
    这篇文章主要为大家展示了“如何解决overlay2存储驱动的磁盘配额问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决overlay2存储驱动的磁盘配额问题”这篇文章吧。为啥要用over...
    99+
    2023-06-04
  • 如何在Ubuntu上查看磁盘使用情况
    在Ubuntu上查看磁盘使用情况可以使用以下几种方法: 使用df命令:在终端中输入df命令,可以列出所有挂载的文件系统及其使用情况...
    99+
    2024-03-12
    Ubuntu
  • mysql存储过程如何变量赋值
    小编给大家分享一下mysql存储过程如何变量赋值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 方法...
    99+
    2024-04-02
  • 如何重复存储在MySQL表的数据列中的值?
    要重复存储在 MySQL 表的数据列中的值,必须将列名作为 REPEAT() 函数的第一个参数传递。使用“Student”表中的数据来演示:示例mysql> Select REPEAT(Name,3)AS Name from...
    99+
    2023-10-22
  • 如何在MySQL中存储图片
    如何在MySQL中存储图片?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先,先要在数据库中建表。我在名为test的数据库下建立了一个叫pic...
    99+
    2024-04-02
  • redis运行在内存如何持久化到磁盘
    redis运行在内存持久化到磁盘的方法:通过配置文件告诉redis通过fsync函数强制os写入到磁盘。appendonly yes #启用aof持久化方式# appendfsync always #每次收到写命令就立即强制写入磁盘,最慢的...
    99+
    2024-04-02
  • 如何在CentOS 7.0上配置Ceph存储
    如何在CentOS 7.0上配置Ceph存储,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。ceph是一个分布式文件系统,能够在维护 POSIX 兼容性的同时加入了复制和容错功能...
    99+
    2023-06-28
  • 如何在CentOS上启用EPEL存储库
    这篇文章给大家介绍如何在CentOS上启用EPEL存储库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。EPEL是一个开放源码的附加软件包储存库,提供了高质量的软件包,可用于CentOS和RHEL服务器。EPEL存储库的...
    99+
    2023-06-28
  • 如何将JSON文件存储在IPFS上
    本篇内容介绍了“如何将JSON文件存储在IPFS上”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!如何将JSON文件存储在IPFS上,并使用O...
    99+
    2023-06-02
  • 如果列中还存储了一些 NULL 值,MySQL COUNT() 函数会返回什么?
    当我们使用 MySQL COUNT() 函数对存储在也存储了一些 NULL 值的列中的值进行计数时,MySQL 会忽略 NULL 并仅返回非 NULL 值的结果。为了理解它,我们使用表“Employee”中的数据,如下所示 -mysql&g...
    99+
    2023-10-22
  • 如何在VirtualBox中设置虚拟机的磁盘缓存
    要在VirtualBox中设置虚拟机的磁盘缓存,可以按照以下步骤操作: 打开VirtualBox,并选择要设置磁盘缓存的虚拟机。 点击“设置”按钮打开虚拟机设置窗口。 在左侧导航栏中选择“存储”选项卡。 在右侧的存储设备列表中,找到要设置...
    99+
    2024-06-10
    virtualbox
  • linux如何在磁盘上创建一个光盘的iso镜像文件
    ...
    99+
    2024-04-02
  • PHP函数如何在Unix系统上存储?
    PHP是一种广泛使用的编程语言,特别是在Web开发中。它支持许多函数,这些函数可用于执行各种任务,例如文件读取、数据库连接等。但是,这些函数在Unix系统上如何存储呢?本文将为您解答这个问题。 在Unix系统上,PHP函数通常存储在共享对象...
    99+
    2023-09-27
    函数 存储 unix
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作