我在一个表中有一个列,它可能包含空值或空值。我如何检查一个列是否为空或空的行中存在的表?
(e.g. null or '' or ' ' or ' ' and ...)
我在一个表中有一个列,它可能包含空值或空值。我如何检查一个列是否为空或空的行中存在的表?
(e.g. null or '' or ' ' or ' ' and ...)
当前回答
select * from table where length(RTRIM(LTRIM(column_name))) > 0
其他回答
try
SELECT 0 IS NULL , '' IS NULL , NULL IS NULL
-> 0, 0, 1
or
SELECT ISNULL(' ') , ISNULL( NULL )
-> 0 ,1
参考
我讨厌数据库中杂乱的字段。如果列可能是一个空白字符串或null,我宁愿在每次执行选择之前修复这个问题,像这样:
UPDATE MyTable SET MyColumn=NULL WHERE MyColumn='';
SELECT * FROM MyTable WHERE MyColumn IS NULL
这可以保持数据整洁,只要您不需要出于某种原因特别区分NULL和empty。
另一种方法没有WHERE,试试这个..
将选择空值和空值
SELECT ISNULL(NULLIF(fieldname,'')) FROM tablename
select * from table where length(RTRIM(LTRIM(column_name))) > 0
我的意见。
在MySQL中,你可以使用COALESCE函数:
返回列表中的第一个非NULL值,如果没有非NULL值,则返回NULL。
所以你可以这样简化你的查询:
SELECT * FROM table WHERE COALESCE(some_col, '') = '';