SAMPLE 표
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
동적 회전의 열을 얻고 당신은 행 및 열 합계 찾을 CUBE
를 사용하여 NULL
을 대체 할 수 zero
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('')),2,8000)
SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]'
와 NULL
교체 생성 된 행에 대해 Total
CUBE
. 당신이 원하는 경우 NULL
대신 0 :
결과

참고 결과
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를 볼 수 있습니다
1 만 표시
- 코드
SELECT @cols += ',[Total]'
및 SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]'
를 사용하지 마십시오 요약 행 : 값으로는 편집 동적 피벗 코드 @cols
대신 @NulltoZeroCols
를 사용합니다.
CUBE
대신 ROLLUP
을 사용하십시오.

2 만보기 열 총
- 를 사용하여 코드
SELECT @cols += ',[Total]'
및 SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]'
.
CUBE
대신 ROLLUP
을 사용하십시오.
GROUP BY Location,PartCode
에서 GROUP BY PartCode,Location
으로 변경하십시오.
ORDER BY CASE WHEN (PartCode=''Total'') THEN 1 ELSE 0 END,PartCode
대신 WHERE PartCode<>''TOTAL'' ORDER BY PartCode
을 사용하십시오.

업데이트 : OP 나는 결과 PartName
을 추가하려면 아래의 쿼리를 업데이트하고
에 대한 PartName
을 가지고. PartName
은 CUBE
과 함께 추가 결과를 추가하고 AND
또는 OR
조건에 혼동을 피하려면 원본 테이블의 DISTINCT
값으로 피벗 된 결과에 참여하는 것이 좋습니다.
- Click here
DECLARE @query NVARCHAR(MAX)
SET @query = 'SELECT P.PartCode,T.PartName,' + @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
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
는

@Sokea를 업데이트했습니다. –
정확히 무엇이 필요합니까? 솔루션 및 설명에 대해 @Sarath Avanavu에게 감사드립니다. – Sokea
환영합니다 :) @Sokea –