为什么推荐mysql存在默认值,而不是null

1、官方原文

首先在了解这个问题之前,我们先看一段mysql官方文档的原文:
在这里插入图片描述

NULL columns require additional space in the row to record whether their values are NULL. Each NULL column takes one bit extra, rounded up to the nearest byte.
我翻译一下:
NULL列需要行中的额外空间来记录它们的值是否为NULL。 每个空列需要额外的一位,四舍五入到最近的字节

很多人说null在数据库中是不占用空间的,也就是说这个回答自然也就不攻而破了,官方都说了null列是需要额外空间去记录的,自然是需要空间的
我们也可以通过测试来看一下具体效果:
在这里插入图片描述
从这段sql中,我们明显的可以看到空字符串的长度为0,是不占用空间的;1是占用了一个长度,而null的长度却是null,正如上图所说null需要行中的额外空间来记录它们到底是不是为null,其实它是占用空间的

不仅如此,null和大多数的计算都不会产生结果,只会产生一个null
在这里插入图片描述
在这里插入图片描述
而能和与null产生联动的也就mysql给的几个关键字,is null、is not null、<=>,甚至平常使用的=也和null毫无关系(mysql的true是返回1,false返回0)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
甚至在某些函数计算中还会影响到最终的结果:
在这里插入图片描述

在这里插入图片描述
虽然count(字段)这个功能我们不常用,但是也明显能看到在计算中对结果造成了影响,count(字段)的数量是肯定小于等于count(*)的

借用知乎@极客小俊的一句话:
通俗意义上讲: (‘’)字符串空值就像是一个真空转态杯子,什么都没有,而NULL值就是一个装满空气的杯子,虽然看起来都是一样的,但是有着本质的区别

2、设置为null的隐患

在MySQL中,对于为什么不推荐字段为NULL,主要有以下几个原因:

  1. 数据一致性:NULL值可能引入数据不一致性。当一个字段允许为NULL时,它可以不包含任何值,这可能导致在查询和处理数据时出现意外的结果。例如,使用NULL值进行数学计算可能导致非预期的结果。

  2. 查询复杂性:使用NULL值可能增加查询的复杂性。在查询数据时,需要处理NULL值的特殊情况,如某些字段为null导致的操作失败的出现,这可能会增加查询逻辑和代码的复杂性。

  3. 存储空间:NULL值需要额外的存储空间。对于每个允许为NULL的字段,MySQL需要为该字段保留额外的空间来表示NULL值,这会增加数据表的存储需求。

  4. 索引效率:NULL值可能降低索引效率。当一个字段允许为NULL时,对该字段的索引可能会变得更大且更稀疏,这会对查询性能产生一定的影响。在MySQL中,使用IS NULL查询条件时,是可以使用索引的。但是需要满足一些条件才能使用。
    4.1 NULL值很少。当NULL值很多时,MySQL可能会选择放弃使用索引而进行全表扫描,因为对于大多数行而言,进行全表扫描比使用索引更快。
    4.2 并且索引列没有重复值。如果索引列中有重复的NULL值,MySQL可能会放弃使用索引,因为在索引中查找NULL值时,需要扫描多个索引条目。
    4.3 使用等于操作符而不是IS NULL。如果使用= NULL进行查询,MySQL可能不会使用索引,因为对于NULL值,等号操作符并不起作用。

3、总结

在设计数据库模式时,如果某个字段预计需要存储值,可以使用默认值或者非空约束来避免NULL值的产生。使用默认值可以确保字段总是包含有效值,非空约束可以强制要求该字段不允许为空。这样可以简化查询逻辑,并提高数据库的性能和可靠性。如果某个字段确实需要存储未知或缺失值,可以考虑使用特殊的占位符值来代替NULL,例如空字符串(“”)或者特定的标识值。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值