Динамически суммировать столбцы таблицы на сервере SQL - PullRequest
1 голос
/ 24 февраля 2020

У меня есть следующие данные в таблице со столбцами Col1, Col2, Col3, Col4, Col5 ......... Col153

Пример данных в первых четырех столбцах таблицы:

CREATE TABLE dbo.MyTable (LocaID VARCHAR(10),Col1 INT, Col2 INT,Col3 INT,Col4 INT)
INSERT INTO dbo.MyTable values
('LV',2,6,4,7),('CH',4,8,3,1),('LV',1,3,9,3),('MC',7,0,5,4),
('LV',4,5,2,4),('MC',7,1,4,9),('MC',5,1,8,1),('CH',7,3,4,0),
('MC',2,5,7,3);

Есть 153 столбца, которые мне нужно суммировать индивидуально. Я использовал запрос ниже, чтобы получить список столбцов:

-- This is to get the columns names
SELECT 
COLUMN_NAME AS Col_Names
INTO #Column
From INFORMATION_SCHEMA.COLUMNS
Where  TABLE_NAME Like 'MyTable'

Я пытался использовать запрос ниже для их динамического суммирования:

DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX);

SET @cols = STUFF((SELECT distinct ',' + QUOTENAME(Col_Names) 
            FROM #Column
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

SET @query= 'SELECT
          SUM('+@cols+')
         FROM dbo.MyTable GROUP BY [LocaID]' 
PRINT @query

Когда я печатаю результат, чтобы проверить, если запрос правильный, я получил это:

SELECT SUM([Col1],[Col2],[Col3],[Col4],[LocaID])
         FROM dbo.MyTable GROUP BY [LocaID]

Что явно не правильно. Что мне нужно, это:

SELECT
[LocaID],
SUM([Col1]) AS [Col1],
SUM([Col2]) AS [Col2],
SUM([Col3]) AS [Col3],
SUM([Col4]) AS [Col4]
FROM dbo.MyTable
GROUP BY [LocaID]

Для всех 153 столбцов. В таблице только один LocaID.

Ответы [ 2 ]

1 голос
/ 24 февраля 2020

Если вы хотите SUM отдельный столбец, вам нужно изменить функцию STUFF. Вам необходимо применить функцию SUM для всех столбцов, как показано ниже.

DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX);

SET @cols = STUFF((SELECT distinct ',SUM(' + QUOTENAME(Col_Names) + ')'
            FROM #Column
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') ,1,1,'')

SET @query= 'SELECT [LocaID], '+@cols+' 
         FROM dbo.MyTable GROUP BY [LocaID]' 
PRINT @query
0 голосов
/ 24 февраля 2020

Большое вам спасибо @Vad Soft, я настроил ваш запрос, чтобы дать мне то, что я хочу

DECLARE @cols AS NVARCHAR(MAX),
        @cols2 AS NVARCHAR(MAX),
        @query  AS NVARCHAR(MAX);
SET @cols = STUFF((
----------------------------------------------------------------------------------
           SELECT DISTINCT CONCAT(',SUM(' + QUOTENAME(a.Col_Names) + ')  AS ',' ',b.RN)
            FROM #Column a
            LEFT JOIN 
            (
            SELECT
Col_Names AS RN

from  #Column
where Col_Names <> 'LocaID' ) b ON b.RN=a.Col_Names
-------------------------------------------------------------------------------------
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') ,1,1,'')  

SET @cols2 =REVERSE(RIGHT(REVERSE(@cols),LEN(REVERSE(@cols))- CHARINDEX(',',REVERSE(@cols)))) 
--PRINT @cols2
SET @query= 'SELECT [LocaID], 
        '+@cols2+'
         FROM dbo.MyTable GROUP BY [LocaID]' 
 --PRINT @cols
 EXEC (@query)
---------------------------
DROP TABLE #Column

Вывод

 print @query

SELECT    [LocaID], 
        SUM([Col1])  AS  Col1,
        SUM([Col2])  AS  Col2,
        SUM([Col3])  AS  Col3,
        SUM([Col4])  AS  Col4
        FROM dbo.MyTable GROUP BY [LocaID]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...