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等)

相关推荐
爱尚你19934 小时前
MySQL 三大日志:redo log、undo log、binlog 详解
数据库·mysql
钢铁男儿7 小时前
Python 正则表达式(正则表达式和Python 语言)
python·mysql·正则表达式
超级迅猛龙9 小时前
保姆级Debezium抽取SQL Server同步kafka
数据库·hadoop·mysql·sqlserver·kafka·linq·cdc
helloyaren10 小时前
Docker Desktop里搭建Mysql 9.4主从复制的保姆级教程
mysql·技术·主从复制
weixin_4565881511 小时前
【java面试day16】mysql-覆盖索引
java·mysql·面试
舒一笑12 小时前
MySQL中模糊匹配like的一个坑
后端·mysql
ejinxian13 小时前
MySQL/Kafka数据集成同步,增量同步及全量同步
数据库·mysql·kafka
@_码农15 小时前
【MySQL的卸载】
mysql
Momentary_SixthSense15 小时前
RESP协议
java·开发语言·javascript·redis·后端·python·mysql
MacroZheng16 小时前
横空出世!一款开源的数据同步工具,稳定又高效,好用到爆!
java·后端·mysql