我在一个表中有一个列,它可能包含空值或空值。我如何检查一个列是否为空或空的行中存在的表?
(e.g. null or '' or ' ' or ' ' and ...)
我在一个表中有一个列,它可能包含空值或空值。我如何检查一个列是否为空或空的行中存在的表?
(e.g. null or '' or ' ' or ' ' and ...)
当前回答
写条件的一种更简短的方法:
WHERE some_col > ''
因为null > "会产生unknown,所以它会过滤掉空字符串和空字符串。
其他回答
写条件的一种更简短的方法:
WHERE some_col > ''
因为null > "会产生unknown,所以它会过滤掉空字符串和空字符串。
try
SELECT 0 IS NULL , '' IS NULL , NULL IS NULL
-> 0, 0, 1
or
SELECT ISNULL(' ') , ISNULL( NULL )
-> 0 ,1
参考
在我的项目中检查一个列的空值或空值时,我注意到在各种数据库中存在一些支持问题。
不是每个数据库都支持TRIM方法。
下面是一个矩阵,只是为了了解不同数据库支持的方法。
SQL中的TRIM函数用于从字符串中删除指定的前缀或后缀。最常被删除的模式是空白。这个函数在不同的数据库中调用方式不同:
MySQL:修剪(),r修剪(),LTRIM() 神谕:RTRIM(), LTRIM() SQL服务器:RTRIM(), LTRIM()
如何检查空/空:-
下面是两种不同的方法根据不同的数据库-
这些trim函数的语法如下:
使用Trim检查- SELECT FirstName FROM UserDetails WHERE TRIM(LastName)为空 使用LTRIM和RTRIM检查- SELECT FirstName FROM UserDetails WHERE LTRIM(RTRIM(LastName))为空
以上两种方法提供相同的结果,只是基于您的数据库支持使用。它只是从UserDetails表返回FirstName,如果它有一个空的LastName
希望这对你有所帮助:)
这句话对我来说更清晰更易读:
select * from my_table where ISNULL(NULLIF(some_col, ''));
select * from table where length(RTRIM(LTRIM(column_name))) > 0