我使用的是SQL Server 2005。我有一个带有文本列的表,在表中有许多行,其中该列的值不是空的,但它是空的。试着对比”会得到这样的回答:

数据类型text和varchar在不等于操作符中是不兼容的。

是否有一个特殊的函数来确定文本列的值是否为空而不是空?


当前回答

我将测试SUBSTRING(textColumn, 0,1)

其他回答

使用DATALENGTH方法,例如:

SELECT length = DATALENGTH(myField)
FROM myTABLE

只获取空值(而不是空值):

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短语,因为与其他类型的搜索相比,它们会降低性能。

它会做两件事: 空检查和字符串空检查 将空值替换为默认值,例如NA。

SELECT coalesce(NULLIF(column_name,''),'NA') as 'desired_name') from table;

我知道这个问题有很多替代答案,但我只是想把我发现的最佳解决方案放在一起,由@Eric Z Beard和@Tim Cooper和@Enrique Garcia和@Uli Köhler。

如果需要处理在用例场景中space-only可能与空相同的事实,因为下面的查询将返回1,而不是0。

SELECT datalength(' ')

因此,我会选择这样的东西:

SELECT datalength(RTRIM(LTRIM(ISNULL([TextColumn], ''))))

我想有一个预定义的文本(“无实验室可用”)显示,如果值为null或空,我的朋友帮助我:

StrengthInfo = CASE WHEN ((SELECT COUNT(UnitsOrdered) FROM [Data_Sub_orders].[dbo].[Snappy_Orders_Sub] WHERE IdPatient = @PatientId and IdDrugService = 226)> 0)
                            THEN cast((S.UnitsOrdered) as varchar(50))
                    ELSE 'No Labs Available'
                    END