3

这是我的桌子。数字是对角线的。

Engineering  Financials  Scope  Schedule  Risks  People
--------------------------------------------------------
1            NULL        NULL   NULL      NULL   NULL
NULL         0           NULL   NULL      NULL   NULL
NULL         NULL        0      NULL      NULL   NULL
NULL         NULL        NULL   0         NULL   NULL
NULL         NULL        NULL   NULL      0      NULL
2            NULL        NULL   NULL      NULL   NULL
NULL         4           NULL   NULL      NULL   NULL
NULL         NULL        3      NULL      NULL   NULL
NULL         NULL        NULL   4         NULL   NULL
NULL         NULL        NULL   NULL      4      NULL
NULL         NULL        NULL   NULL      NULL   0
0            NULL        NULL   NULL      NULL   NULL
NULL         0           NULL   NULL      NULL   NULL
NULL         NULL        0      NULL      NULL   NULL
NULL         NULL        NULL   0         NULL   NULL
NULL         NULL        NULL   NULL      0      NULL
NULL         NULL        NULL   NULL      NULL   0
0            NULL        NULL   NULL      NULL   NULL
NULL         0           NULL   NULL      NULL   NULL
NULL         NULL        0      NULL      NULL   NULL
NULL         NULL        NULL   0         NULL   NULL
NULL         NULL        NULL   NULL      0      NULL
NULL         NULL        NULL   NULL      NULL   0
1            NULL        NULL   NULL      NULL   NULL
NULL         0           NULL   NULL      NULL   NULL
NULL         NULL        5      NULL      NULL   NULL
NULL         NULL        NULL   4         NULL   NULL
NULL         NULL        NULL   NULL      3      NULL
NULL         NULL        NULL   NULL      NULL   3

我希望那些出现在这个输出中:

Engineering  Financials  Scope  Schedule  Risks  People
--------------------------------------------------------
1            0           0      0         0      NULL
2            4           3      4         4      0
0            0           0      0         0      0
0            0           0      0         0      0
0            0           0      0         0      0
1            0           5      4         3      3

实际上,我想将这些对角线行转换为每个部分的单行。

4

2 回答 2

4

结果,您想要的聚合似乎基于表中行的顺序。在表格中,行顺序无关紧要,假设顺序保持不变是危险的。

因此,除非您尚未向我们展示完整的源表(例如其中包含一Section列),否则很难为您提供对这个问题的有用答案。


编辑:

如果您Section列,您可以使用以下查询来获得您想要的结果:

SELECT   Section
         ,SUM(Engineering) AS Engineering
         ,SUM(Financials) AS Financials
         ,SUM(Scope) AS Scope
         ,SUM(Schedule) AS Schedule
         ,SUM(Risks) AS Risks
         ,SUM(People) AS People
FROM     YourTable
GROUP BY Section;

除了使用该SUM函数来聚合您的数据,您还可以使用MAX其他函数,具体取决于数据以及您想从中获得什么。

于 2012-12-07T09:54:46.917 回答
4

这太长了,无法发表评论,所以我正在回答。

目前尚不清楚您的数据来自何处,是数据表还是来自查询。您之前的问题是关于 aPIVOT并且您提供的数据与相同的数据匹配,所以我猜测这是来自该查询。

如果您正在使用PIVOT查询,并且子查询中有太多字段,则可能会发生这种行为。

样本数据查询 1

CREATE TABLE yourtable ([Name] varchar(11), [Rating] int);

INSERT INTO yourtable ([Name], [Rating])
VALUES
    ('Engineering', 1),
    ('Financials', 3),
    ('Scope', 1),
    ('Schedule', 2),
    ('Risks', 3),
    ('People', 3);

将提供正确结果的PIVOT

select *
from
(
  select name, rating
  from yourtable
) src
pivot
(
  max(rating)
  for name in ([Engineering], [Financials], [Scope],
               [Schedule], [Risks], [People])
) piv

请参阅带有演示的 SQL Fiddle

结果如下:

| ENGINEERING | FINANCIALS | SCOPE | SCHEDULE | RISKS | PEOPLE |
----------------------------------------------------------------
|           1 |          3 |     1 |        2 |     3 |      3 |

以上将是正确的语法,因为您有一行条目。现在,如果我稍微改变这个查询,你会看到不同:

示例数据查询 2:我在其中添加了一个id字段

CREATE TABLE yourtable([Name] varchar(11), [Rating] int, id int);

INSERT INTO yourtable([Name], [Rating], id)
VALUES
    ('Engineering', 1, 1),
    ('Financials', 3, 2),
    ('Scope', 1, 3), 
    ('Schedule', 2, 4),
    ('Risks', 3, 5),
    ('People', 3, 6);

如果我执行PIVOT并包含此ID字段,结果将看起来像您的。

枢轴

select [Engineering], [Financials], [Scope], [Schedule], [Risks], [People]
from
(
  select name, rating, id  -- notice the addition of the id column
  from yourtable
) src
pivot
(
  max(rating)
  for name in ([Engineering], [Financials], [Scope],
               [Schedule], [Risks], [People])
) piv

请参阅带有演示的 SQL Fiddle

结果:

| ENGINEERING | FINANCIALS |  SCOPE | SCHEDULE |  RISKS | PEOPLE |
------------------------------------------------------------------
|           1 |     (null) | (null) |   (null) | (null) | (null) |
|      (null) |          3 | (null) |   (null) | (null) | (null) |
|      (null) |     (null) |      1 |   (null) | (null) | (null) |
|      (null) |     (null) | (null) |        2 | (null) | (null) |
|      (null) |     (null) | (null) |   (null) |      3 | (null) |
|      (null) |     (null) | (null) |   (null) | (null) |      3 |

正如您所看到的,添加这个额外的列重现了您遇到的问题。我的建议是发布您的表结构,然后发布您用来获取结果的查询。从那时起,我们将能够为您提供帮助。

于 2012-12-07T10:40:10.130 回答