基于“由另一列的SUM分列的SUM” SQL查询透视(SQL Pivot query based o

2019-10-28 13:28发布

。我试图找出如何基于由另一列”的总和除以一个特定列的SUM转动我的数据这里是我到目前为止已经达到,但PIVOT查询给我的错误:

USE MyDatabase

SELECT  [PropertyCode],
        [Market],
        [JANUARY 2015],
        [FEBRUARY 2015],
        [MARCH 2015]

FROM (SELECT [PropertyCode],
             [Market],  
             [MTH],
             [GN],
             [PkgRev]


     FROM   HOLDINGS

     ) a

 PIVOT (Sum([PkgRev])/Sum([GN])
         FOR [MTH] IN ([JANUARY 2015],
                   [FEBRUARY 2015],
                   [MARCH 2015])) as pvttable

ORDER BY [PROPERTYCODE]

在上面的查询HOLDINGS是VIEW表和PkgRev和GN是在该视图表列。 我需要我的透视查询执行由GN列的总和除以PkgRev列的SUM后返回值。

下面是数据的样本(来自HOLDINGS视图表):

PropertyCode    ID  GN  MTH    Pkg Rev  Market
   A            1   10  Jan-15  95,652  United Kingdom
   A            3   20  Jan-15  95,652  United Kingdom
   A            12  24  Feb-15  81,610  France
   A            15  14  Feb-15  47,606  France
   B            16  18  Jan-15  38,153  France
   B            20  28  Feb-15  69,391  United Kingdom
   B            22  32  Jan-15  107,990 Germany
   B            25  28  Feb-15  76,696  United Kingdom
   C            26  4   Jan-15  18,961  Germany
   C            27  26  Jan-15  56,522  South Africa
   C            29  20  Feb-15  27,826  India
   C            31  18  Jan-15  33,661  France
   C            32  14  Jan-15  26,039  Germany

预期输出如下:

PropertyCode    Market           Jan-15     Feb-15
     A          France             0         3,400
     A          United Kingdom     6,377       0
     B          France             2,120       0
     B          Germany            3,375       0
     B          United Kingdom     0         2,609
     C          France             1,870       0
     C          Germany            1,607       0
     C          India              0         1,391
     C          South Africa       2,174       0

Answer 1:

当旋转你应该记住的是:1: aggregation and spreading elements cannot directly be results of expressions 2:分组元素都identified by elimination

我可以建议你重写如下:

DECLARE @t TABLE
    (
      ProperTyCode CHAR(1) ,
      ID INT ,
      GN int ,
      MTH NVARCHAR(10) ,
      Pkg int ,
      Market NVARCHAR(20)
    )

INSERT  INTO @t
VALUES  ( 'A', 1, 10, 'Jan-15', 95652, 'United Kingdom' ),
        ( 'A', 3, 20, 'Jan-15', 95652, 'United Kingdom' ),
        ( 'A', 12, 24, 'Feb-15', 81610, 'France' ),
        ( 'A', 15, 14, 'Feb-15', 47606, 'France' ),
        ( 'B', 16, 18, 'Jan-15', 38153, 'France' ),
        ( 'B', 20, 28, 'Feb-15', 69391, 'United Kingdom' ),
        ( 'B', 22, 32, 'Jan-15', 107990, 'Germany' ),
        ( 'B', 25, 28, 'Feb-15', 76696, 'United Kingdom' ),
        ( 'C', 26, 4, 'Jan-15', 18961, 'Germany' ),
        ( 'C', 27, 26, 'Jan-15', 56522, 'South Africa' ),
        ( 'C', 29, 20, 'Feb-15', 27826, 'India' ),
        ( 'C', 31, 18, 'Jan-15', 33661, 'France' ),
        ( 'C', 32, 14, 'Jan-15', 26039, 'Germany' );
WITH    cte
          AS ( SELECT   [PropertyCode] ,
                        [Market] ,
                        [MTH] ,
                        CAST(ROUND(SUM([Pkg])  / CAST(SUM([GN]) AS DECIMAL(20, 5)), 0) AS INT) AS [GR]
               FROM     @t
               GROUP BY [PropertyCode] ,
                        [Market] ,
                        [MTH]
             )
    SELECT  [PropertyCode] ,
            [Market] ,
            ISNULL([Jan-15], 0) AS [Jan-15],
            ISNULL([Feb-15], 0) AS [Feb-15]
    FROM    cte PIVOT ( MAX([GR]) FOR [MTH] IN ( [Jan-15], [Feb-15] ) ) AS pvttable
    ORDER BY [PROPERTYCODE]

输出:

PropertyCode    Market          Jan-15  Feb-15
A               France          0       3400
A               United Kingdom  6377    0
B               France          2120    0
B               Germany         3375    0
B               United Kingdom  0       2609
C               France          1870    0
C               Germany         2500    0
C               India           0       1391
C               South Africa    2174    0    


文章来源: SQL Pivot query based on “SUM of a column divided by SUM of another column”