看看我的例子,两个代码有什么区别?
Select name from customers where name is not null
Select name from customers where name <> ''
他们做完全不同的事情。
Select name from customers where name is not null
此选项选择名称字段中具有值的任何客户。这些值可以包括“”以及“Sam”、“John Jones”、“漂亮金发女孩”等内容。
Select name from customers where name <> ''
这将选择至少在 Sql Server 中不为空或空白的所有名称。其他数据库可能会以不同的方式处理此问题。它也排除 Null 的原因是 Null 不能成为比较的一部分,因为根据定义,它意味着我们不知道该字段的值是什么。
如果您想同时返回真实姓名和空值并且仅排除空字符串。在 SQL Server 中你会这样做:
Select name from customers where coalesce(name, 'Unknown') <>''
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)