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

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

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


当前回答

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

其他回答

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

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

你必须做到这两点:

从文本为空或类似文本的表中选择*

null和空字符串是等价的吗?如果它们是,我会在我的应用程序中包括逻辑(或者可能是一个触发器,如果应用程序是“开箱即用”?)强制字段为null或“,但不是其他。如果你使用",那么你也可以将列设置为NOT NULL。只是数据清洁的问题。

我知道这个帖子很古老,但是我发现它很有用。

它没有解决我的问题,返回记录与非空文本字段,所以我认为我将添加我的解决方案。

这就是where从句对我有用。

WHERE xyz LIKE CAST('% %' as text)

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

SELECT * FROM mytable WHERE mytextfield LIKE ''