首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在整个表中查找空单元格,而不指定OR条件下的所有列名

在整个表中查找空单元格,而不指定OR条件下的所有列名
EN

Stack Overflow用户
提问于 2014-10-27 22:06:52
回答 1查看 1.4K关注 0票数 0

我的表中有190列,我试图列出空的或空白的单元格。我已经知道如何在where子句中使用OR来检查这个条件,但不知道。在190个列中,我尝试了很长的work....So,以便列出空值,但是当我根据我的标准更改查询时,将'IS NULL'替换为'',以获得空单元格,这是行不通的

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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;

请提前指导我,谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-27 22:17:04

尝尝这个

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT @sql += N' OR convert(varchar(50),' + Quotename(name) + ')='''''
FROM   sys.columns
WHERE  [object_id] = Object_id(@tb);

检查这个示例,我没有发现任何错误。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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; 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26601835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文