我的表中有190列,我试图列出空的或空白的单元格。我已经知道如何在where
子句中使用OR
来检查这个条件,但不知道。在190个列中,我尝试了很长的work....So,以便列出空值,但是当我根据我的标准更改查询时,将'IS NULL'
替换为''
,以获得空单元格,这是行不通的
DECLARE @tb NVARCHAR(255) = N'dbo.[Sales_Five_Years]';
DECLARE @sql NVARCHAR(MAX) = N'SELECT * FROM ' + @tb
+ ' WHERE 1 = 0';
SELECT @sql += N' OR ' + QUOTENAME(name) + ' IS NULL'
FROM sys.columns
WHERE [object_id] = OBJECT_ID(@tb);
EXEC sp_executesql @sql;
请提前指导我,谢谢
发布于 2014-10-27 22:17:04
尝尝这个
SELECT @sql += N' OR convert(varchar(50),' + Quotename(name) + ')='''''
FROM sys.columns
WHERE [object_id] = Object_id(@tb);
检查这个示例,我没有发现任何错误。
CREATE TABLE pr1
(
col VARCHAR(50),
col1 VARCHAR(50)
)
INSERT INTO pr1
SELECT '',NULL
UNION
SELECT NULL,'a'
UNION
SELECT 'b','a'
SELECT @sql += N' OR convert(varchar(50),' + Quotename(name) + ')='''''
FROM sys.columns
WHERE [object_id] = Object_id(@tb);
PRINT @sql
EXEC Sp_executesql
@sql;
https://stackoverflow.com/questions/26601835
复制相似问题