Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

Общата сума на ред и колона в динамична ос

ПРИМЕРНА ТАБЛИЦА

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

Вземете колоните за динамично завъртане и заменете 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]'

Можете да използвате CUBE за да намерите общата сума на ред и колона и да замените NULL с Total за редовете, генерирани от CUBE .

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

РЕЗУЛТАТ

ЗАБЕЛЕЖКА:Ако искате NULL вместо zero като стойности използвайте @cols вместо @NulltoZeroCols в динамичен обобщен код

РЕДАКТИРАНЕ:

1. Показване само на общ ред

  • Не използвайте кода SELECT @cols += ',[Total]' и SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]' .
  • Използвайте ROLLUP вместо CUBE .

2. Показване само на общата колона

  • Използвайте кода SELECT @cols += ',[Total]' и SELECT @NullToZeroCols += ',ISNULL([Total],0) AS [Total]' .
  • Използвайте ROLLUP вместо CUBE .
  • Промяна на 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 .

АКТУАЛИЗИРАНЕ:За въвеждане на 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)),''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



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SharePoint 2010 - Промяна от Kerberos към удостоверяване на базата на твърдения

  2. Получавате грешка при изпълнение на динамичен sql в рамките на функция (SQL Server)?

  3. .NET API за SQL Server Service Broker

  4. СЪЗДАЙТЕ ТАБЛИЦА, АКО НЕ СЪЩЕСТВУВА, еквивалент в SQL Server

  5. Изпращане на имейли с прикачени файлове в SQL Server (T-SQL)