带Pivot的SQL查询即使使用Isnull也显示Null
我正在使用这个查询,但它一直显示空值而不是0,我已经尝试了很多方法,但无法让它在空值上返回0带Pivot的SQL查询即使使用Isnull也显示Null,sql,sql-server,tsql,Sql,Sql Server,Tsql,我正在使用这个查询,但它一直显示空值而不是0,我已经尝试了很多方法,但无法让它在空值上返回0 select p.* from ( select 'Ordenado Base' as Custos, nome, sum(isnull(prre.ere,0)) as OBase from pr inner join prre on pr.prstamp = prre.prstamp where year(pr.data) = 2017 and prre.
select p.* from
(
select 'Ordenado Base' as Custos, nome, sum(isnull(prre.ere,0)) as OBase
from pr
inner join prre on pr.prstamp = prre.prstamp
where year(pr.data) = 2017 and prre.cr = 1
group by nome
) as Tabela1
Pivot(
sum(Tabela1.Obase)
for nome in ([Alexandra Maria da Costa Migueis],[ALEXANDRE PEDRO GOMES FREITAS],[Amílcar Leonardo dos Santos],[Ana Filipa Leitão Costa Martins Claro Viana Machado],[ANA PATRICIA FRED FILIPE]) as P
您需要将查询更改为在选择列表中包含ISNULL。 假设[Alexandra Maria da Costa Migueis]没有任何Obase值,则其下的值将为NULL
select
Custos,
[Alexandra Maria da Costa Migueis]=ISNULL([Alexandra Maria da Costa Migueis],0),
[ALEXANDRE PEDRO GOMES FREITAS]=ISNULL([ALEXANDRE PEDRO GOMES FREITAS],0),
[Amílcar Leonardo dos Santos]=ISNULL([Amílcar Leonardo dos Santos],0),
[Ana Filipa Leitão Costa Martins Claro Viana Machado]=ISNULL([Ana Filipa Leitão Costa Martins Claro Viana Machado],0),
[ANA PATRICIA FRED FILIPE]=ISNULL([ANA PATRICIA FRED FILIPE],0)
from
(
select
'Ordenado Base' as Custos,
nome,
sum(isnull(prre.ere,0)) as OBase
from pr
inner join prre on pr.prstamp = prre.prstamp
where year(pr.data) = 2017 and prre.cr = 1
group by nome
) as Tabela1
Pivot
(
sum(Tabela1.Obase)
for nome in
(
[Alexandra Maria da Costa Migueis],
[ALEXANDRE PEDRO GOMES FREITAS],
[Amílcar Leonardo dos Santos],
[Ana Filipa Leitão Costa Martins Claro Viana Machado],
[ANA PATRICIA FRED FILIPE]
)-- was missing
) as P