mysql - 为什么MySQL不建议使用NULL作为列默认值?

为什么MySQL不建议使用NULL作为列默认值?

InnoDB有4中行格式:

  • Redundant : 非紧凑格式,5.0 版本之前用的行格式,目前很少使用,
  • Compact : 紧凑格式,5.1 版本之后默认行格式,可以存储更多的数据
  • Dynamic , Compressed : 和Compact类似,5.7 版本之后默认使用 Dynamic 行格式,在Compact基础上做了改进,基础设计原理没变

由于Redundant较少使用, 且Dynamic和Compressed是基于Compact的, 故这里以Compact为例。

Compact行格式如下:

存储的额外数据 存储的真实数据
变长数据列的长度 NULL值的列表 记录头信息 row_id (隐藏字段) trx_id (隐藏字段) roll_ptr (隐藏字段) 列1 列2 ... 列n

由于:

  1. NULL值列表的数量, 与允许为null的字段数量一致 如, 有7个字段允许为null, 则有7个NULL值列表
  2. NULL值列表至少占用1字节空间, 故当数据量越大或null列越多时, 占用的存储空间越多

综上所述, 不建议允许列为null, 可使用其他默认值(如空字符串, 0等)

相关推荐
知行0210 分钟前
MySQL的Docker版本,部署在ubantu系统
数据库·mysql·docker
朝新_21 分钟前
【MySQL】第三弹——表的CRUD进阶(一)数据库约束
数据库·mysql
Eternity......2 小时前
spark MySQL数据库配置
数据库·mysql·spark
脑子慢且灵3 小时前
MySQL:关系模型的基本理论
数据库·sql·mysql
敲上瘾3 小时前
MySQL基本查询
数据库·mysql·数据库开发·数据库架构·数据库系统
敲上瘾4 小时前
MySQL数据库表的约束
linux·数据库·sql·mysql·数据库开发·数据库架构·数据库系统
努力的搬砖人.4 小时前
SQLite 转换为 MySQL 数据库
数据库·mysql·sqlite
2301_803297754 小时前
Shell编程值正则表达式和文本处理器
数据库·mysql·正则表达式
老李不敲代码5 小时前
榕壹云搭子系统技术解析:基于Spring Boot+MySQL+UniApp的同城社交平台开发实践
spring boot·mysql·微信小程序·uni-app·软件需求
zhou1855 小时前
MySQL保姆级安装教程(附资源包+5分钟极速配置+环境变量调试技巧)
java·python·mysql·php