3

是否可以为 PIVOT 操作定义“回退”或“其他”情况?让我玩一下 MSDN 中的示例:

-- Pivot table with one row and five columns
SELECT
    'AverageCost' AS Cost_Sorted_By_Production_Days, 
    [0], [1], [2], [3], [4],
    [??magicalELSEkeyword??] as 'too many days'

FROM
(
    SELECT DaysToManufacture, StandardCost 
    FROM Production.Product
) AS SourceTable

PIVOT
(
    AVG(StandardCost)
    FOR DaysToManufacture IN
    (
        [0], [1], [2], [3], [4],
        [??magicalELSEkeyword??]
    )
) AS PivotTable;

枢轴行为非常明显 - 它在指定值列表的出现上选择/案例/组。我想看到的是一个“后备”案例。在上面的查询中,我想获取:

  • “即时” 0 天流程的平均成本
  • 1天流程的平均成本
  • ...
  • 4天流程的平均成本
  • 所有其他人的平均成本

请注意,“通缉”案件列表是不变的并且是已知的。我不想产生未知列数的枢轴。我只想将所有不匹配的值分组为名为“其他”的简单结果

我在MSDN上的 T-SQL 语法参考中没有看到任何这种可能性,我只是觉得很难相信这是不可用的。它似乎是一个非常有用的功能并且实现起来微不足道,省略它只是很痛苦..

是的,我知道它可能会引入讨论是否以及如何处理出现在“其他”中的 NULL 值,但这只是两种特殊情况..它们可以像在任何聚合函数中一样被忽略——这对实现,并且 100% 良好并且与 SQL 的其余部分保持一致——或者可以由两个不同的备用关键字处理,例如 ELSE-NOT-NULL 与 ELSE-OR-NULL..

这个功能真的没有了吗?

4

1 回答 1

5

不幸的是,不可能将other放在ELSE语句中,所以我会将 放在CASE您的子查询中。然后,您将PIVOT使用这些新值:

select *
from
(
  select StandardCost,
    case DaysToManufacture
      when 0 then '0'
      when 1 then '1'
      when 2 then '2'
      when 3 then '3'
      when 4 then '4'
      else 'Others' end as DaysToManufacture
  from Product
) src
pivot
(
  avg(StandardCost)
  for DaysToManufacture in ([0], [1], [2], [3], [4], [Others])
) piv

请参阅带有演示的 SQL Fiddle

于 2013-02-01T15:35:26.997 回答