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

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

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


当前回答

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

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

其他回答

实际上,你只需要使用LIKE操作符。

SELECT * FROM mytable WHERE mytextfield LIKE ''

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

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

使用IS NULL操作符:

Select * from tb_Employee where ename is null
DECLARE @temp as nvarchar(20)

SET @temp = NULL
--SET @temp = ''
--SET @temp = 'Test'

SELECT IIF(ISNULL(@temp,'')='','[Empty]',@temp)

试试这个:

select * from mytable where convert(varchar, mycolumn) = ''

希望能帮到你!