沈阳网站建设首选龙兴科技,做网站毕设答辩问题,营销型网站设计,电白网站开发公司为什么MySQL不建议使用NULL作为列默认值#xff1f;
InnoDB有4中行格式#xff1a;
Redundant : 非紧凑格式,5.0 版本之前用的行格式,目前很少使用,Compact : 紧凑格式,5.1 版本之后默认行格式,可以存储更多的数据Dynamic , Compressed : 和Compact类似,5.7 版本之后默认使…为什么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
由于
NULL值列表的数量, 与允许为null的字段数量一致 如, 有7个字段允许为null, 则有7个NULL值列表 NULL值列表至少占用1字节空间, 故当数据量越大或null列越多时, 占用的存储空间越多
综上所述, 不建议允许列为null, 可使用其他默认值如空字符串, 0等