sql-server-2008 – 动态数据透视表中的行和列总数
|
在SQL Server 2008中,我有一个包含3列的表(tblStock):
下面的一些示例数据: PartCode StockQty Location
......... ......... .........
A 10 WHs-A
B 22 WHs-A
A 1 WHs-B
C 20 WHs-A
D 39 WHs-F
E 3 WHs-D
F 7 WHs-A
A 9 WHs-C
D 2 WHs-A
F 54 WHs-E
如何创建程序以获得如下结果? PartCode WHs-A WHs-B WHs-C WHs-D WHs-E WHs-F Total ........ ..... ..... ..... ...... ..... ..... ..... A 10 1 9 0 0 0 20 B 22 0 0 0 0 0 22 C 20 0 0 0 0 0 20 D 2 0 0 0 0 39 41 E 0 0 0 3 0 0 3 F 7 0 0 0 54 0 61 Total 61 1 9 3 54 39 167 非常感谢您的帮助,谢谢. 解决方法样本表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,9,'WHs-C' UNION ALL SELECT 'D',2,'WHs-A' UNION ALL SELECT 'F',54,'WHs-E' )TAB 获取用于动态旋转的列并将零替换为NULL 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 += ',[Total]'
--Varible 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('')),8000)
SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]'
您可以使用CUBE查找行和列总计,并将CUBE生成的行替换为NULL. DECLARE @query NVARCHAR(MAX)
SET @query = 'SELECT PartCode,' + @NulltoZeroCols + ' FROM
(
SELECT
ISNULL(CAST(PartCode AS VARCHAR(30)),''Total'')PartCode,SUM(StockQty)StockQty,ISNULL(Location,''Total'')Location
FROM #tblStock
GROUP BY Location,PartCode
WITH CUBE
) x
PIVOT
(
MIN(StockQty)
FOR Location IN (' + @cols + ')
) p
ORDER BY CASE WHEN (PartCode=''Total'') THEN 1 ELSE 0 END,PartCode'
EXEC SP_EXECUTESQL @query
> Click here查看结果 结果 注意:如果您想要NULL而不是零作为值,请在动态数据透视代码中使用@cols而不是@NulltoZeroCols 编辑: 1.仅显示行总计 >不要使用代码SELECT @cols =’,[Total]’和SELECT @NullToZeroCols =’,0)AS [Total]’. 2.仅显示列总计 >使用代码SELECT @cols =’,0)AS [Total]’. 更新:为OP带来PartName 我正在更新以下查询以添加带有结果的PartName.由于PartName将使用CUBE添加额外的结果并避免在AND或OR条件中出现混淆,因此最好将轮转结果与源表中的DISTINCT值相结合. DECLARE @query NVARCHAR(MAX)
SET @query = 'SELECT P.PartCode,T.PartName,' + @NulltoZeroCols + ' FROM
(
SELECT
ISNULL(CAST(PartCode AS VARCHAR(30)),PartCode
WITH CUBE
) x
PIVOT
(
MIN(StockQty)
FOR Location IN (' + @cols + ')
) p
LEFT JOIN
(
SELECT DISTINCT PartCode,PartName
FROM #tblStock
)T
ON P.PartCode=T.PartCode
ORDER BY CASE WHEN (P.PartCode=''Total'') THEN 1 ELSE 0 END,P.PartCode'
EXEC SP_EXECUTESQL @query
> Click here查看结果 (编辑:清远站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

