Ger*_*man 5 sql sql-server-2008
有没有办法计算除PrimaryKey列之外的特定记录的空值的所有字段?
Example:
ID Name Age City Zip
1 Alex 32 Miami NULL
2 NULL 24 NULL NULL
Run Code Online (Sandbox Code Playgroud)
作为输出,我需要得到1和3.没有明确指定列名.
Mik*_*son 15
declare @T table
(
ID int,
Name varchar(10),
Age int,
City varchar(10),
Zip varchar(10)
)
insert into @T values
(1, 'Alex', 32, 'Miami', NULL),
(2, NULL, 24, NULL, NULL)
;with xmlnamespaces('http://www.w3.org/2001/XMLSchema-instance' as ns)
select ID,
(
select *
from @T as T2
where T1.ID = T2.ID
for xml path('row'), elements xsinil, type
).value('count(/row/*[@ns:nil = "true"])', 'int') as NullCount
from @T as T1
Run Code Online (Sandbox Code Playgroud)
结果:
ID NullCount
----------- -----------
1 1
2 3
Run Code Online (Sandbox Code Playgroud)
更新:
这是一个更好的版本.感谢Martin Smith.
;with xmlnamespaces('http://www.w3.org/2001/XMLSchema-instance' as ns)
select ID,
(
select T1.*
for xml path('row'), elements xsinil, type
).value('count(/row/*[@ns:nil = "true"])', 'int') as NullCount
from @T as T1
Run Code Online (Sandbox Code Playgroud)
更新:
并且使用更快的XQuery表达式.
;with xmlnamespaces('http://www.w3.org/2001/XMLSchema-instance' as ns)
select ID,
(
select T1.*
for xml path('row'), elements xsinil, type
).value('count(//*/@ns:nil)', 'int') as NullCount
from @T as T1
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4849 次 |
最近记录: |