Используя 2 группы, можно ли разбить 2-ю группу на столбцы? - PullRequest
0 голосов
/ 31 марта 2020

У меня есть запрос, похожий на этот:

SELECT dateadd(DAY,0, datediff(day,0, archivedate)) as day, 
    COUNT(*) item_value,
    item_metadata.item_label
FROM item_values
join item_metadata on item_values.md_ID= item_metadata.Id
group by dateadd(DAY,0, datediff(day,0, archivedate)), item_label
order by dateadd(DAY,0, datediff(day,0, archivedate)) desc

Это приводит к данным, которые выглядят так:

day       item_value    item_label
2020-03-31  8           orange
2020-03-31  2           black
2020-03-30  28          green
2020-03-30  1           blue
2020-03-30  59          orange
2020-03-29  11          black
2020-03-29  1           blue
2020-03-29  15          green
2020-03-29  4           orange

Я хочу, чтобы это выглядело так:

day         orange   black   green   blue
2020-03-31  8        2       0       0
2020-03-30  59       0       28      1
2020-03-29  4        11      15      1 

Возможно ли это на SQL сервере?

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

РЕШЕНО На основании других ссылок, опубликованных ниже, решение, которое я нашел, было:

 declare
    @cols nvarchar(max),
    @stmt nvarchar(max)

select @cols = isnull(@cols + ', ', '') + '[' + T.item_label + ']' from (select distinct item_label from item_metadata where Active=1) as T

select @stmt = '
select * from (SELECT dateadd(DAY,0, datediff(day,0, archivedate)) as [day], 
COUNT(*) as item_value,
item_label
  FROM item_values
  join item_metadata on item_values.md_ID= item_metadata.Id
   where Ignored=0 group by dateadd(DAY,0, datediff(day,0, archivedate)),item_label ) Visits
    pivot(sum(item_value) for item_metadata
    in (' + @cols + ') ) as pivottable order by day desc
'
exec sp_executesql  @stmt = @stmt

1 Ответ

1 голос
/ 31 марта 2020

Демонстрация на дб <> fiddle

Возможно, вы ищете Dynami c Сводный запрос


DECLARE 
    @columns NVARCHAR(MAX) = '',
    @sql     NVARCHAR(MAX) = '';


SELECT @columns += QUOTENAME(item_label) + ','
From (SELECT DISTINCT item_label 
      FROM #a) A

-- remove the last comma
SET @columns = LEFT(@columns, LEN(@columns) - 1);


SET @sql = 'SELECT * 
            FROM ( SELECT day,item_value,item_label 
                   FROM  #a) src 
                   PIVOT( MAX([item_value]) FOR item_label IN ('+ @columns +')) AS pivot_table;';

-- execute the dynamic SQL
EXECUTE sp_executesql @sql;

Выход

enter image description here

...