[MySQL] 空值新发现

本文讲述了在MySQL中使用LeftJoin时遇到的一个陷阱,即空字符串()与数字0被视为等价,在进行表连接时可能导致意外的结果行增加。通过具体案例分析了这一问题的原因,并给出了相应的解决建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前些天碰到一个很有趣的问题,客服的同事提出一个新的需求,希望在现有的每日报告中增加一个字段。我一看,现在的每日报告是从A表中抓取当日的数据生成csv文件的,如果需要增加该字段的话,需要以A表中的商品ID作为key,和B表中的商品ID进行匹配即可。

所以我使用了Left join语句进行数值匹配,并且提交了改动。然而在随后的测试中发现,改动后的每日报告行数多出很多,并且有大量商品ID为空白的情况(即那个作为key的column)。反复研究后发现,还是left join惹的货。

A表中有部分商品ID为空白字符串的行,即“”。

而B表中有大量商品ID为0的行,即0。

而当A表和B表以商品ID为key进行匹配时,“”会和0匹配在一起,从而产生大量商品ID为空白的新的行。进一步试验后,我们发现,以下语句:

select 0 = "";

会返回1,即true。所以在mysql中0和“”是对等的关系。

而0,“‘和null的关系就没有那么紧密了。无论是0,还是”“, 都不会被认为等于null。所以在key存在”“或者0的值时,作left join要尤其注意,不要让”“和0莫名地匹配上产生多余的结果行来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值