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

基于MySQL在磁盘上存储NULL值

2024-04-02 19:04:59 796人浏览 薄情痞子
摘要

目录1 为何不能直接存个NULL?2 到底怎么存储?3 一行数据的磁盘存储格式4 如何读磁盘的一行数据?1 为何不能直接存个NULL? NULL值列表,一行数据里可能有的字段值是NU

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值的文章就介绍到这了,更多相关在磁盘上存储NULL值内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

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

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

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

猜你喜欢
  • 基于MySQL在磁盘上存储NULL值
    目录1 为何不能直接存个NULL?2 到底怎么存储?3 一行数据的磁盘存储格式4 如何读磁盘的一行数据?1 为何不能直接存个NULL? NULL值列表,一行数据里可能有的字段值是NU...
    99+
    2024-04-02
  • 如何基于MySQL在磁盘上存储NULL值
    小编给大家分享一下如何基于MySQL在磁盘上存储NULL值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 为何不能直接存个NULL?NULL值列表,一行数据里可...
    99+
    2023-06-29
  • MySQL null值存储和null性能影响
    这篇文章主要介绍“MySQL null值存储和null性能影响”,在日常操作中,相信很多人在MySQL null值存储和null性能影响问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • MySQL Innodb 存储结构 和 存储Null值 用法详解
    背景: 表空间:INNODB 所有数据都存在表空间当中(共享表空间),要是开启innodb_file_per_table,则每张表的数据会存到单独的一个表空间内(独享表空间)。 独享表空间包括:数据,索引,插入缓存...
    99+
    2022-05-11
    MySQL Innodb 存储结构 存储Null值
  • 将mysql存储位置迁移到一块新磁盘上的方法
    小编给大家分享一下将mysql存储位置迁移到一块新磁盘上的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.准备一块新的磁盘...
    99+
    2024-04-02
  • BOOLEAN 或 TINYINT 在 MySQL 中存储值?
    MySQL的BOOLEAN和BOOL都等同于TINYINT(1)。每当你使用BOOLEAN和BOOL数据类型创建列时,MySQL会隐式地将BOOLEAN和BOOL转换为TINYINT(1)。BOOLEAN和BOOL是TINYINT(1)的等...
    99+
    2023-10-22
  • Android上的基于协程的存储框架
    在Android上,经常会需要持久化本地数据,比如我们需要缓存用户的配置信息、用户的数据、缓存数据、离线缓存数据等等。我们通常使用的工具为SharePreference、MMKV、DataStore、Room、文件等等。通过使用现有的存储框...
    99+
    2023-09-10
    android 协程 MMKV Flow Kotlin
  • MySQL 存储函数如何在使用表中的动态值时评估它是否获得 NULL 值?
    在这种情况下,当存储函数获取 NULL 值时,它将返回 NULL 作为结果。从下面的例子可以看出,学生‘Mohit’的记录中有一个NULL值。现在,当我们对此数据应用存储的函数“avg_marks”时,它将返回 NULL 作为结果。mysq...
    99+
    2023-10-22
  • Oracle_rac在vmware上面安装时,udev磁盘没有scsi_id返回值
    这段时间在客户vmware上面安装了一套oracle11g_rac,是基于redhat6.4系统的,之前做redhat5版本的时候,都是有现成的asmlib工具可用,但红帽6起初是没有对应版本asmlib,...
    99+
    2024-04-02
  • MySQL中的''、' '和 NULL在Innodb存储的区别
    这篇文章主要介绍“MySQL中的''、' '和 NULL在Innodb存储的区别”,在日常操作中,相信很多人在MySQL中的''、' '和 N...
    99+
    2024-04-02
  • 无法在磁盘上找到确实存在的文件或目录
    对于一个Golang开发者来说,牢固扎实的基础是十分重要的,编程网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《无法在磁盘上找到确实存在的文件或目录》,主要介绍了,希望对大家的知识积累有...
    99+
    2024-04-04
  • MySQl事务面试整理(基于InnoDB存储引擎)
    最近看了很多关于事务问题的博客,感觉看的好混乱,没有一个整体的架构来谈事务; 所以就根据自己的见解谈一谈关于事务的问题。 1.事务四大特征(ACID) 众所周知,事务的四大特性即原子性,持久性,隔离性和一致性, 一致性是事务的最终目的,而...
    99+
    2021-04-15
    MySQl事务面试整理(基于InnoDB存储引擎)
  • 如果列中还存储了一些 NULL 值,MySQL COUNT() 函数会返回什么?
    当我们使用 MySQL COUNT() 函数对存储在也存储了一些 NULL 值的列中的值进行计数时,MySQL 会忽略 NULL 并仅返回非 NULL 值的结果。为了理解它,我们使用表“Employee”中的数据,如下所示 -mysql&g...
    99+
    2023-10-22
  • 怎么在mysql存储过程中返回多个值
    本篇文章为大家展示了怎么在mysql存储过程中返回多个值,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql存储函数只返回一个值。要开发返回多个值的存储过程,需...
    99+
    2024-04-02
  • 怎样在磁盘上查找MySQL表的大小?这里有答案
    我想知道 MySQL 表在磁盘上占用多少空间,但看起来很琐碎。不应该在 INFORMATION_SCHEMA.TABLES 中提供这些信息吗没那么简单! 我想知道 MySQL 表在磁盘上占用多少空间...
    99+
    2024-04-02
  • 如何重复存储在MySQL表的数据列中的值?
    要重复存储在 MySQL 表的数据列中的值,必须将列名作为 REPEAT() 函数的第一个参数传递。使用“Student”表中的数据来演示:示例mysql> Select REPEAT(Name,3)AS Name from...
    99+
    2023-10-22
  • 基于MySQL中存储引擎与日志说明的示例分析
    这篇文章主要介绍基于MySQL中存储引擎与日志说明的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.1 存储引擎的介绍1.1.1 文件系统存储文件系统:操作系统组织和存取数...
    99+
    2024-04-02
  • 在 MySQL 数据库中存储货币值的最佳数据类型?
    为了表示金钱,我们需要使用 Decimal (TotalDigitsinteger, DigitsAfterDecimalinteger) 方法。 假设我们需要显示值 345.66。为此,计算有多少位可用。值345.66,一共有5位,小数点...
    99+
    2023-10-22
  • 您是否需要一份关于在 Linux 上使用 Go 存储的教程?
    随着现代技术的发展,越来越多的开发者开始使用Go语言来构建应用程序。Go语言是一种现代化的编程语言,它的特点是运行速度非常快,同时也非常易于使用。Linux是一种非常流行的操作系统,也是大多数开发者首选的操作系统之一。在Linux上使用Go...
    99+
    2023-11-06
    存储 linux 教程
  • Go 语言中的数组和打包:如何将数据存储在硬盘上?
    Go 语言是一种开源的编程语言,它是由 Google 公司开发的。它是一种类型安全且具有垃圾回收机制的编程语言。Go 语言支持数组和打包,这使得它成为一种非常有用的编程语言。在本文中,我们将探讨在 Go 语言中如何使用数组和打包来存储数据。...
    99+
    2023-07-01
    存储 数组 打包
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作