sql – 选择值为NULL的列名称
发布时间:2021-02-20 14:35:33 所属栏目:MsSql 来源:互联网
导读:好的,4个小时的编码,只有6个小时的搜索…,我没有比我开始时更好.这是我的问题我有一个表(tmp Shell),它有12列.这是一个没有约束的基本表,用于临时报告.当我们插入数据时,我必须提取一个ID号(PatientId)和所有列NAMES,其中该PatientID的值为null. 例: Patient
好的,4个小时的编码,只有6个小时的搜索…,我没有比我开始时更好.这是我的问题我有一个表(tmp Shell),它有12列.这是一个没有约束的基本表,用于临时报告.当我们插入数据时,我必须提取一个ID号(PatientId)和所有列NAMES,其中该PatientID的值为null. 例: PatientIdFnameLnameDOB 123455SamNULLNULL 我想回来的是: PatientIdErrorMsg 123455Lname,DOB 当然,如果所有的列都有一个值,那么errormsg将为null. 我尝试并失败了大约300个不同的代码,但这似乎是我能得到的最接近的.不幸的是,这只返回EVERY列,而不是空值. ALTER PROC [sp_aaShowAllNullColumns] @tableName VARCHAR(255) AS BEGIN SET NOCOUNT ON; DECLARE @sql NVARCHAR(4000); DECLARE @cols NVARCHAR(4000); DECLARE @tcols TABLE ( [colbit] NVARCHAR(255) ); --DECLARE @tablename VARCHAR(255) = 'tmpShell'; INSERT @tcols SELECT 'count(' + [columns].[name] + ') as ' + [columns].[name] + ',' AS [colbit] FROM [sys].[columns] WHERE [columns].[object_id] = OBJECT_ID(@tableName); SELECT @cols = COALESCE(@cols,','') + [@tcols].[colbit] FROM @tcols; SELECT @cols = SUBSTRING(@cols,1,( LEN(@cols) - 1 )); SELECT @cols = ISNULL(@cols,''); SELECT @sql = 'select patientid,count(*) as Rows' + @cols + ' from ' + @tableName + ' group by patientid having count(*) > 0'; CREATE TABLE [tmpShell2] ( [patientid] VARCHAR(15),[Rows] CHAR(2),[Rn] CHAR(2),[patId] CHAR(2),[fname] CHAR(2),[lname] CHAR(2),[dob] CHAR(2),[addr1] CHAR(2),[city] CHAR(2),[state] CHAR(2),[zip] CHAR(2),[country] CHAR(2),[psite] CHAR(2),[csite] CHAR(2),[ssite] CHAR(2),[scode] CHAR(2),[sfid] CHAR(2),[taskid] CHAR(2),[errormsg] CHAR(2) ); INSERT INTO [tmpShell2] EXEC [sys].[sp_executesql] @sql; DECLARE @tbl VARCHAR(255) = 'tmpShell2'; SELECT DISTINCT [TS].[patientid],STUFF(( SELECT DISTINCT ',' + [C].[name] FROM [tmpShell2] AS [TS2] JOIN [sys].[columns] AS [C] ON [C].[object_id] = OBJECT_ID(@tbl) WHERE [C].[name] NOT IN ( 'SFID','TaskId','ErrorMsg' ) AND [C].[name] IS NOT NULL FOR XML PATH('') ),'') FROM [tmpShell2] AS [TS]; DROP TABLE [dbo].[tmpShell2]; END; GO EXEC [sp_aaShowAllNullColumns] 'tmpShell'; </pre> 解决方法这样的东西怎么样?SELECT a.PatientID,CASE a.tmpCol WHEN '' THEN NULL ELSE STUFF(a.tmpCol,'') END AS ErrorMsg FROM ( SELECT PatientID,CASE WHEN FirstName IS NULL THEN ',FirstName' ELSE '' END + CASE WHEN LastName IS NULL THEN ',LastName' ELSE '' END + CASE WHEN DOB IS NULL THEN ',DOB' ELSE '' END AS tmpCol FROM <tableName> ) a; (编辑:莱芜站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- SQL Server -- 回忆笔记(一):初见数据库
- Select count(*)、Count(1)和Count(列)的区别及执
- SQL Server -- 回忆笔记(五):T-SQL编程,系统
- sql-server – SQL Server 2014备份到2012年
- SQLServer 数据库故障修复顶级技巧之一
- Sql Server中的事务介绍
- sql-server – SQL Server 2008在Insert,Update之
- sql-server – 如何在没有CLR的SQL Server 2008中
- sql-server-2008 – 无法连接到Windows Vista上的
- 用户 jb51net 登录失败。原因: 该帐户的密码必须
热点阅读