【问题标题】:Replacing null values in dynamic pivot sql query替换动态数据透视 sql 查询中的空值
【发布时间】: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


【解决方案1】:

您需要为 select 语句生成另一个列列表,并用 ISNULL 包装各个月份,如下所示:

DECLARE @cols AS NVARCHAR(MAX),
        @selectCols AS NVARCHAR(MAX),
        @query AS NVARCHAR(MAX) 

SELECT  @selectCols = STUFF
(
(
SELECT distinct ', ISNULL(' + QUOTENAME([MONTH]) + ', 0) AS ' + 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,''
)



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],' + @selectCols + ' 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)

【讨论】:

  • 然而,我得到了同样的结果!
  • @Khushal_Jain 是的,这是因为这几个月的记录缺失。请参阅我编辑的答案,您需要将选择列包装在 ISNULL 中。
  • 感谢@MarcinJ,但现在我收到如下错误-
  • 'CONCAT' 不是可识别的内置函数名称。
  • 感谢@MarcinJ,更新后的查询确实有效,只是我必须从 selectCols 代码声明中删除 "ORDER BY ',' + QUOTENAME([MONTH]) DESC" 子句
猜你喜欢
  • 2022-08-16
  • 1970-01-01
  • 2021-08-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-10-28
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多