当前位置: 首页 > news >正文

深入解析:MySQL 中 NULL 值是否占用 1 bit 存储空间?

在 MySQL 的存储机制中,关于 NULL 值是否占用 1 bit 的存储空间,存在一个常见的理解误区。许多人认为“每个 NULL 值占用 1 bit”,但这并不完全准确。本文将通过 InnoDB 引擎的存储原理,详细解释 NULL 值的实际存储开销,并澄清这一误解。


一、核心结论

  1. 允许为 NULL 的列会引入位掩码(Bitmask) ,但 位掩码的开销是按字节分配,而非按单个 NULL 值分配。
  2. NULL 值本身不存储数据内容,但通过位掩码标记是否为 NULL
  3. 固定长度类型(如 INT)的 NULL 值不占用数据空间,仅通过位掩码标记。
  4. 可变长度类型(如 VARCHAR)的 NULL 值同样不占用数据空间,但比空字符串('')节省 1-2 字节的长度信息。

二、位掩码机制详解

1. 位掩码的作用

InnoDB 的每行数据开头有一个 NULL 位掩码,用于标记哪些允许为 NULL 的列实际存储了 NULL 值。

  • 每个允许为 NULL 的列在位掩码中对应 1 bit
  • 位掩码的总大小按字节向上取整
    位掩码字节数 = ⌈允许为 NULL 的列数 / 8⌉

示例

  • 若表中有 5 个允许为 NULL 的列,位掩码占用 1 字节(5/8=0.625 → 向上取整为1)。
  • 若有 9 个允许为 NULL 的列,位掩码占用 2 字节

2. 位掩码的存

相关文章:

  • “三小时搞定AI工具开发“:基于MCP的Node.js极简实践
  • Optional的stream方法,flatMap, filter应用
  • Imgui处理glfw的鼠标键盘的方法
  • stable diffusion webui 更改为python3.11版本运行Windows11
  • 【C++】右值引用与完美转发
  • 软件工程面试题(十)
  • 妙用《甄嬛传》中的选妃来记忆概率论中的乘法公式
  • 交换技术综合实验
  • 第四章.4.3.1ESP32传感器数据采集与滤波处理实战教程
  • 从0开始——在PlatformIO下开展STM32单片机的HAL库函数编程指南
  • ​​​​​​​​​​​​​​Spring Boot数据库连接池
  • Vue学习笔记集--computed
  • 蓝桥杯-特殊的多边形(dfs/前缀和)
  • 指针和引用
  • 业务流程先导及流程图回顾
  • YOLO基础知识
  • 【C语言文件精选题】
  • 《网络管理》实践环节01:OpenEuler22.03sp4安装zabbix6.2
  • 验证Linux多进程时间片切换的程序
  • PyTorch 张量的new_tensor方法介绍
  • 孙磊已任中国常驻联合国副代表、特命全权大使
  • 工行一季度净赚841亿元降3.99%,营收降3.22%
  • 国家发改委下达今年第二批810亿超长期特别国债资金,支持消费品以旧换新
  • 中介在网上非法贩婴“一个孩子8.5万元”?丹阳警方介入
  • 坚守刑事检察一线13年,“在我心中每次庭审都是一次大考”
  • 加拿大温哥华一车辆冲撞人群,造成多人伤亡