Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/80.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 动态透视中的行和列平均值_Sql_Sql Server_Sql Server 2005 - Fatal编程技术网

Sql 动态透视中的行和列平均值

Sql 动态透视中的行和列平均值,sql,sql-server,sql-server-2005,Sql,Sql Server,Sql Server 2005,在SQL Server 2008中,我有一个包含3列的表tblStock: PartCode (NVARCHAR (50)) StockQty (INT) Location (NVARCHAR(50)) 以下是一些示例数据: 我想得到以下输出 我编写了以下查询以获取上述输出,Avg值未正确返回: IF OBJECT_ID('tempdb..#tblStock') IS NOT NULL /*Then it exists*/ DROP TABLE #tblStock SELEC

在SQL Server 2008中,我有一个包含3列的表
tblStock

PartCode (NVARCHAR (50))
StockQty (INT)
Location (NVARCHAR(50))
以下是一些示例数据:

我想得到以下输出

我编写了以下查询以获取上述输出,
Avg
值未正确返回:

IF OBJECT_ID('tempdb..#tblStock') IS NOT NULL /*Then it exists*/ 
    DROP TABLE #tblStock 

SELECT * 
INTO #tblStock
FROM
    (SELECT 'A' PartCode,  10 StockQty, 'WHs-A' Location
     UNION ALL
     SELECT 'B',   22,  'WHs-A'
     UNION ALL
     SELECT 'A',   1,   'WHs-B'
     UNION ALL
     SELECT 'C',   20,  'WHs-A'
     UNION ALL
     SELECT 'D',   39,  'WHs-F'
     UNION ALL
     SELECT 'E',   3,   'WHs-D'
     UNION ALL
     SELECT 'F',   7,   'WHs-A'
     UNION ALL
     SELECT 'A',   9,   'WHs-C'
     UNION ALL
     SELECT 'D',   2,   'WHs-A'
     UNION ALL
     SELECT 'F',   54,  'WHs-E') TAB

SELECT * FROM #tblStock 

DECLARE @cols NVARCHAR (MAX)
SELECT @cols = COALESCE (@cols + ',[' + Location + ']', '[' + Location + ']')
               FROM (SELECT DISTINCT Location FROM #tblStock) PV 
               ORDER BY Location 
-- Since we need Total in last column, we append it at last
SELECT @cols += ',[AVG]'

-- Variable to replace NULL with zero
DECLARE @NulltoZeroCols NVARCHAR (MAX)
SELECT @NullToZeroCols = SUBSTRING((SELECT ',ISNULL(['+Location+'],0) AS ['+Location+']' 
FROM (SELECT DISTINCT Location FROM #tblStock)TAB  
ORDER BY Location FOR XML PATH('')),2,8000) 
SELECT @NullToZeroCols += ',ISNULL([AVG],0) AS [AVG]'


DECLARE @query NVARCHAR(MAX)
SET @query = 'SELECT PartCode,' + @NulltoZeroCols + ' FROM 
             (
                 SELECT 
                 ISNULL(CAST(PartCode AS VARCHAR(30)),''AVG'')PartCode, 
                 AVG(StockQty) StockQty  , 
                 ISNULL(Location,''AVG'')Location              
                 FROM #tblStock
                 GROUP BY Location,PartCode
                 WITH CUBE
             ) x
             PIVOT 
             (
                 AVG(StockQty)
                 FOR Location IN (' + @cols + ')
            ) p
            ORDER BY CASE WHEN (PartCode=''AVG'') THEN 1 ELSE 0 END,PartCode' 

EXEC SP_EXECUTESQL @query 

有人知道这个问题的解决方案吗?

我用这个来更改集合查询,从而获得您想要的结果。
我认为您需要添加正确的联接以列出每个零件代码和位置(否则AVG函数无法正确计算项目数)。我也将ISNULL添加到了平均库存量中。 此外,您应该将平均值转换为数字

SET @query = 'SELECT PartCode,' + @NulltoZeroCols + ' FROM 
             (SELECT                    
                 ISNULL(CAST(X.PC AS VARCHAR(30)),''AVG'') PartCode, 
                 AVG(CAST(ISNULL(StockQty,0) AS NUMERIC(10,2))) StockQty,                  
                 ISNULL(Y.LC,''AVG'') Location              
                 FROM #tblStock
                 RIGHT JOIN (SELECT DISTINCT PartCode AS PC FROM #tblStock)  X
                          CROSS JOIN  (SELECT DISTINCT Location AS LC FROM #tblStock) Y
                  ON Y.LC = #tblStock.LOCATION AND X.PC=#tblStock.PARTCODE
                 GROUP BY  Y.LC, X.PC  
                 WITH CUBE                 
             ) x
             PIVOT 
             (
                 AVG(StockQty)
                 FOR Location IN (' + @cols + ')
            ) p
            ORDER BY CASE WHEN (PartCode=''AVG'') THEN 1 ELSE 0 END,PartCode' 
输出:

PartCode                       WHs-A                                   WHs-B                                   WHs-C                                   WHs-D                                   WHs-E                                   WHs-F                                   AVG
------------------------------ --------------------------------------- --------------------------------------- --------------------------------------- --------------------------------------- --------------------------------------- --------------------------------------- ---------------------------------------
A                              10.000000                               1.000000                                9.000000                                0.000000                                0.000000                                0.000000                                3.333333
B                              22.000000                               0.000000                                0.000000                                0.000000                                0.000000                                0.000000                                3.666666
C                              20.000000                               0.000000                                0.000000                                0.000000                                0.000000                                0.000000                                3.333333
D                              2.000000                                0.000000                                0.000000                                0.000000                                0.000000                                39.000000                               6.833333
E                              0.000000                                0.000000                                0.000000                                3.000000                                0.000000                                0.000000                                0.500000
F                              7.000000                                0.000000                                0.000000                                0.000000                                54.000000                               0.000000                                10.166666
AVG                            10.166666                               0.166666                                1.500000                                0.500000                                9.000000                                6.500000                                4.638888