質問編集履歴
1
前提を少し細かく記載しました。
title
CHANGED
File without changes
|
body
CHANGED
@@ -1,7 +1,8 @@
|
|
1
1
|
#1. Rubyを使用した表現について
|
2
2
|
|
3
|
+
カレンダーアプリで特定のイベントの一週間分の日毎の回数をグラフで表す際のバックエンド側の処理を実装しています。
|
3
4
|
以下rubyまたはactive recordのメソッドでEventテーブルから特定のiconの条件にマッチするstartの時間を取り出してその数を直近一週間分を日毎にカウントし歯抜け部分には0で埋めるようにするテーブルの作成を考えいています。
|
4
|
-
具体的には以下のようになります。
|
5
|
+
具体的には以下のようになります。(startのデータの型はdatetimeとなり,event作成の際に日付を整形しております。)
|
5
6
|
元のテーブル
|
6
7
|

|
7
8
|
|
@@ -22,7 +23,7 @@
|
|
22
23
|
```
|
23
24
|
と書いて日付範囲の指定なしで該当する日付のカウントをとるところまではできておりますが、日付の連番の仮想テーブルの作成とleft join をruby表現できず、以下の通りsqlを生で書いて対応しております。
|
24
25
|
解決策が分かる方はよろしくお願いします。
|
25
|
-
なお、
|
26
|
+
なお、postgereSQLでは以下のように書いてます。
|
26
27
|
```
|
27
28
|
SELECT d.start_date, coalesce(r.count, 0) AS count
|
28
29
|
FROM (
|
@@ -38,7 +39,7 @@
|
|
38
39
|
GROUP BY to_char(start,'MM-DD'), icon
|
39
40
|
) AS r ON d.start_date = r.start_date
|
40
41
|
```
|
41
|
-
# 2.Railsでのメソッドの書き方
|
42
|
+
# 2.Rails上でpostgereSQLを使った場合のメソッドの書き方
|
42
43
|
実際にrailsに書くと以下のような感じとなりました。
|
43
44
|
event.rb
|
44
45
|
```
|