データベースから、過去 X 日間に更新されたプロファイルを見つけて、日付に基づいてグループ化しようとしています。
私のSQL構造は次のようになります:
id (int)
date_modified (date)
次のような結果が生成されます。
+----+---------------+
| id | date_modified |
+----+---------------+
| 86 | 2012-06-22 |
| 87 | 2012-06-22 |
| 88 | 2012-06-22 |
| 89 | 2012-06-22 |
| 63 | 2011-10-31 |
| 72 | 2012-02-06 |
| 60 | 2011-10-17 |
| 71 | 2012-02-29 |
| 69 | 2011-11-18 |
| 76 | 2012-02-29 |
| 70 | 2011-11-18 |
| 75 | 2012-02-29 |
| 73 | 2012-02-06 |
| 74 | 2012-02-28 |
| 77 | 2012-02-29 |
| 80 | 2012-05-07 |
| 82 | 2012-06-12 |
| 83 | 2012-08-15 |
| 84 | 2012-09-07 |
| 85 | 2012-08-15 |
+----+---------------+
理想的には、次のような結果が得られるようにクエリを実行したいと思います。
+-------+----------+
| total | days_ago |
+-------+----------+
| 4 | 1 |
| 6 | 2 |
| 8 | 3 |
| 12 | 7 |
| 3 | 30 |
| 55 | 90 |
| 28 | 180 |
| 37 | 270 |
| 42 | 360 |
+----+-------------+
date_modified を数日前に変換し、上記の増分でグループ化しています。
選択クエリのケースを使用してこれが可能であると想定していますが、それを行う方法について少し途方に暮れています。