週ごとにグループ化されたSQL結果を選択する 質問する

週ごとにグループ化されたSQL結果を選択する 質問する

次の表から週ごとにデータを選択したい

 Date       Product Name   Sale
+----------+--------------+-----+
 14-05-11     a             2
 14-05-11     b             4 
 17-05-11     c             3
 19-05-11     a             6
 24-05-11     a             6
 29-05-11     a             6    

今日は30-05-11

結果は次のようになるはずです。

 Product Name         First Week   Second Week  Third Week
+--------------------+------------+------------+-------------+
   a                      12            6           2
   b                       0            0           4 
   c                       0            3           0  

この動作を実現するための SQL クエリの書き方を誰か教えていただけませんか。

ベストアンサー1

これで大丈夫だと思います。

Select 
ProductName,
WeekNumber,
sum(sale)
from
(
    SELECT 
    ProductName,
    DATEDIFF(week, '2011-05-30', date) AS WeekNumber,
    sale
    FROM table
)
GROUP BY
ProductName,
WeekNumber

おすすめ記事