mysql null问题续

本文探讨了MySQL中处理NULL值和空字符串时遇到的问题,包括比较运算符的行为异常及COUNT函数对NULL的处理方式,并提出了使用IFNULL函数解决这些问题的方法。

上回说到group_concat和concat的时候,如果有列值为null,则concat后为null。

现在发现另一个问题,如果有列A为null,而另一列B为空'',那么A<>B与A=B的记录条数之和不等于总数。

也就是说,如果列A为null,列B为空'',那么mysql是不会比较它们的,即这种情况既不属于相等,也不属于不相等。

解决办法就是用ifnull(sqlserver是isnull)函数:ifnull(A,'')。把null转换成空之后再和B比较。

另外,select count(idc_position.id) from ** 这个语句run时,如果表中有些行的id这个字段为Null,那么,select count(id) 返回记录行数时,将不会把id为null的行算在内,自动干掉了这些行。

又一个陷阱……

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值