我在一个表中有一个列,它可能包含空值或空值。我如何检查一个列是否为空或空的行中存在的表?

(e.g. null or '' or '  ' or '      ' and ...)

当前回答

try

SELECT 0 IS NULL ,  '' IS NULL , NULL IS NULL

-> 0, 0, 1

or

SELECT ISNULL('  ') , ISNULL( NULL )
 -> 0 ,1

参考

其他回答

这将选择some_col为NULL或"(空字符串)的所有行

SELECT * FROM table WHERE some_col IS NULL OR some_col = '';

在我的项目中检查一个列的空值或空值时,我注意到在各种数据库中存在一些支持问题。

不是每个数据库都支持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

希望这对你有所帮助:)

我的意见。

在MySQL中,你可以使用COALESCE函数:

返回列表中的第一个非NULL值,如果没有非NULL值,则返回NULL。

所以你可以这样简化你的查询:

SELECT * FROM table WHERE COALESCE(some_col, '') = '';

另一种方法没有WHERE,试试这个..

将选择空值和空值

SELECT ISNULL(NULLIF(fieldname,''))  FROM tablename

try

SELECT 0 IS NULL ,  '' IS NULL , NULL IS NULL

-> 0, 0, 1

or

SELECT ISNULL('  ') , ISNULL( NULL )
 -> 0 ,1

参考