【发布时间】:2019-04-04 07:33:10
【问题描述】:
图像转录:
FTE/RATE CARD | 2018-01-01 | 2018-02-01 | 2018-03-01 | 2018-04-01 | 2018-05-01 | 2018-06-01 | ...
-------------------------------------------------------------------------------------------------
FTE 3 | NULL | NULL | NULL | 33 | 38 | 40.5 | ...
我有一个如下所示的数据透视 sql 查询。 我需要在结果中用零替换 NULL 值。 我不知道在查询中究竟在哪里使用 IsNull 或 Coalesce 函数。
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX)
SELECT @cols = STUFF
(
(
SELECT distinct ',' + QUOTENAME([MONTH])
FROM [HEADCOUNT]
WHERE [MONTH] BETWEEN '01-012018' AND '12-01-2018'
ORDER BY ',' + QUOTENAME([MONTH])
FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'),1,1,''
)
SET @query = 'SELECT [FTE/RATE CARD],' + @cols + ' FROM
(
SELECT [MONTH],[FTE/RATE CARD],[HC]
FROM [HEADCOUNT]
WHERE [CC-LOC] IN ([CC-LOC])
) x pivot (Sum ([HC]) for [MONTH] in (' + @cols + '))p' execute(@query)
【问题讨论】:
-
您使用的是哪个 dbms? (该查询是特定于产品的。)
-
Microsoft SQL Server 管理工作室
-
那不是 RDBMS @Khushal_Jain,那是一个应用程序。但它确实回答了这个问题。
标签: sql-server tsql sql-server-2008 dynamic-sql