SQL Server PIVOT - 多个聚合函数

14

给定以下结果集:

---------------------------------------------------------
CustomerID  Service  TransType  SubTotal   Tax   NetTotal
---------------------------------------------------------
106            A        CREDIT     12.52     -      12.52 
106            A        CREDIT     10.07     -      10.07
106            B        CREDIT      2.00     -       2.00
106            C        REMOTE      5.99     -       5.99
106            C        CREDIT      5.99     -       5.99
106            C        CREDIT      3.99  0.30       3.69
106            C        CREDIT      5.99  0.30       5.69
106            D        CREDIT      5.99     -       5.99
---------------------------------------------------------

请注意NetTotal = SubTotal - Tax

请帮助我按以下方式计算sum(SubTotal)、sum(Tax)和sum(NetTotal),以及透视后的TransType:

--------------------------------------------------------------------------
CustomerID  Service  Cash  Check  Credit  Remote  SubTotal   Tax  NetTotal
--------------------------------------------------------------------------
106            A        0      0   22.59       0     22.59     0     22.59   
106            B        0      0    2.00       0      2.00     0      2.00    
106            C        0      0   15.97    5.99     21.96  0.60     21.36    
106            D        0      0    5.99       0      5.99     0      5.99    
--------------------------------------------------------------------------

如果我只需要对一个列进行汇总,使用PIVOT很容易,但我不确定如何获取三个聚合值 - SubTotal(小计)、Tax(税)和NetTotal(净总额)。

谢谢你的帮助!

2个回答

28

不需要使用 PIVOT 就可以完成此操作:

SELECT 
  CustomerID
, [Service]
, Cash = SUM(case when TransType='CASH' then SubTotal else 0 end)
, [Check] = SUM(case when TransType='CHECK' then SubTotal else 0 end)
, Credit = SUM(case when TransType='CREDIT' then SubTotal else 0 end)
, [Remote] = SUM(case when TransType='REMOTE' then SubTotal else 0 end)
, SubTotal = SUM(SubTotal)
, Tax = SUM(Tax)
, NetTotal = SUM(NetTotal)
FROM YourTable
GROUP BY CustomerId, [Service]

使用PIVOT会变得更加复杂。我能想到的最简单的方法是在不同的查询中计算SubTotal、Tax和NetTotal,然后再将查询与join组合起来。以下是示例;为了保持查询简单,我已经放弃了Cash和Check。

SELECT  
  a.CustomerId
, a.Service
, Credit = a.Credit
, [Remote] = a.[Remote]
, SubTotal = SUM(b.SubTotal)
, Tax = SUM(b.Tax)
, NetTotal = SUM(b.NetTotal)
FROM (
    SELECT 
      CustomerId
    , [Service]
    , Credit = SUM(Credit)
    , [Remote] = SUM([Remote])
    FROM YourTable a
    PIVOT
    (
        SUM(SubTotal) FOR [TransType] IN ([Credit],[Remote])
    ) pvt
    GROUP BY CustomerId, [Service]
) a
INNER JOIN YourTable b 
    ON a.CustomerID = b.CustomerID 
    AND a.[Service] = b.[Service]
GROUP BY a.CustomerId, a.[Service], a.Credit, a.[Remote]

谢谢Andomar!我一直局限于使用PIVOT,忽略了像你给我的这个更简单的解决方案。非常感谢你的帮助! - Gus Cavalcanti

7
你尝试过像这样的东西吗?
DECLARE @Table TABLE(
        CustomerID INT,
        [Service] VARCHAR(MAX),
        TransType VARCHAR(MAX),
        SubTotal FLOAT,
        Tax FLOAT,
        NetTotal FLOAT
)

INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'A', 'CREDIT', 12.52, 0 , 12.52
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'A', 'CREDIT', 10.07, 0 , 10.07
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'B', 'CREDIT', 2, 0 , 2
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'C', 'REMOTE', 5.99, 0 , 5.99
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'C', 'CREDIT', 5.99, 0 , 5.99
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'C', 'CREDIT', 3.99, 0.3 , 3.69
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'C', 'CREDIT', 5.99, 0.3 , 5.69
INSERT INTO @Table (CustomerID,[Service],TransType,SubTotal,Tax,NetTotal)
SELECT 106, 'D', 'CREDIT', 5.99, 0 , 5.99

SELECT  Pivots.CustomerID,
        Pivots.[Service],
        Pivots.Cash,
        Pivots.[Check],
        Pivots.Credit,
        Pivots.[Remote],
        Total.SumSubTotal,
        Total.SumTax,
        Total.SumNetTotal
FROM    (
            SELECT  CustomerID,
                    [Service],
                    [Cash] Cash,
                    [Check] [Check],
                    [Credit] Credit,
                    [Remote] [Remote]
            FROM    (
                        SELECT  CustomerID,
                                [Service],
                                TransType,
                                SubTotal
                        FROM    @Table
                    ) sub
                    PIVOT
                    (
                        SUM(SubTotal)
                        FOR [TransType] IN ([Cash],[Check],[Credit],[Remote])
                    ) pvt
            ) Pivots INNER JOIN
            (                       
                SELECT  CustomerID,
                        [Service],
                        SUM(SubTotal) SumSubTotal,
                        SUM(Tax) SumTax,
                        SUM(NetTotal) SumNetTotal
                FROM    @Table
                GROUP BY CustomerID,
                        [Service]
            ) Total ON  Pivots.CustomerID = Total.CustomerID
                    AND Pivots.[Service] = Total.[Service]

谢谢 astander。我将另一个答案标记为正确,因为它以更简单的方式解决了问题。尽管如此,我非常感谢您的回答。 - Gus Cavalcanti

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接