SQL - Tabela dinâmica e grupo por não funcionar
Eu tenho uma tabela da seguinte forma:
Product #users Date Count Type
prodA 29 2013-02-27 113 Document
prodA 31 2013-03-02 152 Extraction
prodB 17 2013-02-26 40 Document
prodB 28 2013-03-02 73 Extraction
Eu preciso usar uma tabela dinâmica na coluna [Type] / Count e obter uma tabela da seguinte maneira:
Product #users Date Document Extraction
prodA 60 2013-03-02 113 152
prodB 45 2013-03-02 40 73
em que a coluna #user é a soma do grupo por produto e a Data é a data máxima do grupo por produto.
Isto é o que eu tenho até agora:
SELECT Product,
sum(users),
max([Date]),
[Document],[Extraction] FROM Table
PIVOT
( sum([Count]) FOR [Type] IN ( Document , Extraction)) AS [QUANTITY]
GROUP BY activity, document, extraction
mas meus resultados finais me dão algo assim:
Product #users Date Document Extraction
prodA 31 2013-03-02 NULL 152
prodA 29 2013-02-27 113 NULL
prodB 28 2013-03-02 NULL 73
prodB 17 2013-02-26 40 NULL
Não está agrupando pelo produto!
Alguma ideia?
EDITAR:
Até agora eu tenho
WITH Pivoted
AS
(
SELECT *
FROM table1
PIVOT
(
sum([Count]) FOR [Type] IN ( Document ,
Extraction)
) AS p
)
SELECT
product,
SUM(Users) AS TotalUsers,
MAX(DAte) AS LatestDate,
MAX(Document) AS Document,
MAX(Extraction) AS Extraction
FROM Pivoted
GROUP BY Product;
mas minha table1 acima é realmente feita de códigos abaixo:
WITH a
AS(
SELECT activity,
username,
[Last Accessed] = max(DATEADD(dd, DATEDIFF(d, 0, ActDateTime), 0)), --[#Users] = count(distinct username),
CASE WHEN COUNT(activity)IS NOT NULL THEN 1 ELSE 0 END AS Count,
CASE WHEN pageURL LIKE '/Document%'
OR pageURL LIKE '/Database%' THEN 'Document' ELSE 'Extraction' END AS [Type] --into #temp
from activitylog
where pageURL not like '%home%' AND pageURL not like '/Default%'
--AND ActDateTime >= @StartDate AND ActDateTime <= @EndDate
group by activity,
username,
--department,
DATEADD(dd, DATEDIFF(d, 0, ActDateTime), 0),
CASE WHEN pageURL LIKE '/Document%' OR pageURL LIKE '/Database%' THEN 'Document' ELSE 'Extraction' END
--order by activity--, username, department,DATEADD(dd, DATEDIFF(d, 0, ActDateTime), 0)
)
,b as
(select activity, count(distinct username) as [Users] ,
--department ,
max([Last Accessed]) as [Last Accessed1],count([count])as [Count],[Type] from a --into #temp1 from #temp
group by activity,
--department,
[Type]
)
select * from b order by activity;
então minha pergunta é, como eu coloco o pedaço de código acima que faz Table1 dentro do primeiro WITH AS?
obrigado