次のようなテーブルがあります。
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
[Type]/Count 列でピボット テーブルを使用し、次のようにテーブルを取得する必要があります。
Product #users Date Document Extraction
prodA 60 2013-03-02 113 152
prodB 45 2013-03-02 40 73
ここで、#user 列は製品別の合計グループであり、Date は製品別の最大日付グループです。
これは私がこれまでに得たものです:
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
しかし、私の最終結果は代わりに次のようなものを与えてくれます:
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
商品ごとのグループ分けではありません!
何か案は?
編集:
これまでのところ、私は
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;
しかし、上記の表1は実際には以下のコードで構成されています:
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;
だから私の質問は、Table1を最初のWITH AS内に作成する上記のコードのチャンクをどのように配置すればよいですか?
ありがとう