我使用的是SQL Server 2005。我有一个带有文本列的表,在表中有许多行,其中该列的值不是空的,但它是空的。试着对比”会得到这样的回答:
数据类型text和varchar在不等于操作符中是不兼容的。
是否有一个特殊的函数来确定文本列的值是否为空而不是空?
我使用的是SQL Server 2005。我有一个带有文本列的表,在表中有许多行,其中该列的值不是空的,但它是空的。试着对比”会得到这样的回答:
数据类型text和varchar在不等于操作符中是不兼容的。
是否有一个特殊的函数来确定文本列的值是否为空而不是空?
当前回答
它会做两件事: 空检查和字符串空检查 将空值替换为默认值,例如NA。
SELECT coalesce(NULLIF(column_name,''),'NA') as 'desired_name') from table;
其他回答
null和空字符串是等价的吗?如果它们是,我会在我的应用程序中包括逻辑(或者可能是一个触发器,如果应用程序是“开箱即用”?)强制字段为null或“,但不是其他。如果你使用",那么你也可以将列设置为NOT NULL。只是数据清洁的问题。
实际上,你只需要使用LIKE操作符。
SELECT * FROM mytable WHERE mytextfield LIKE ''
DECLARE @temp as nvarchar(20)
SET @temp = NULL
--SET @temp = ''
--SET @temp = 'Test'
SELECT IIF(ISNULL(@temp,'')='','[Empty]',@temp)
我知道这个问题有很多替代答案,但我只是想把我发现的最佳解决方案放在一起,由@Eric Z Beard和@Tim Cooper和@Enrique Garcia和@Uli Köhler。
如果需要处理在用例场景中space-only可能与空相同的事实,因为下面的查询将返回1,而不是0。
SELECT datalength(' ')
因此,我会选择这样的东西:
SELECT datalength(RTRIM(LTRIM(ISNULL([TextColumn], ''))))
只获取空值(而不是空值):
SELECT * FROM myTable WHERE myColumn = ''
获取空值和空值:
SELECT * FROM myTable WHERE myColumn IS NULL OR myColumn = ''
只获取空值:
SELECT * FROM myTable WHERE myColumn IS NULL
获取非null和empty的值:
SELECT * FROM myTable WHERE myColumn <> ''
记住,只在必要时使用LIKE短语,因为与其他类型的搜索相比,它们会降低性能。