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

相关推荐
梦三辰1 小时前
超详细解读:数据库MVCC机制
数据库·mysql·mvcc·快照
hxung3 小时前
如何保证mysql和redis的数据一致性
java·数据库·redis·mysql
翻滚吧键盘3 小时前
debian12 mysql完全卸载
数据库·mysql
安得权3 小时前
Ubunut18.04 离线安装MySQL 5.7.35
数据库·mysql·adb
在下千玦3 小时前
#在docker中启动mysql之类的容器时,没有挂载的数据...在后期怎么把数据导出外部
mysql·docker·容器
白鸽(二般)4 小时前
mysql
数据库·mysql
欲儿4 小时前
Spring Boot 下 MySQL Redis双重复用提高服务器性能
运维·服务器·spring boot·redis·mysql
Three~stone4 小时前
MySQL学习笔记集--触发器
笔记·学习·mysql
乐大师5 小时前
MySQL查看binlog执行情况
数据库·mysql·binlog
羑悻的小杀马特5 小时前
MySQL 查询重写怎样把复杂查询变简单,让查询提高一个“速”!
mysql·查询重写