teratail header banner
teratail header banner
質問するログイン新規登録

質問編集履歴

1

前提を少し細かく記載しました。

2020/07/14 02:00

投稿

ItiroWakuda
ItiroWakuda

スコア9

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
  ![](4e44bf811d43a95873a010c9e70cca95.png)
7
8
 
@@ -22,7 +23,7 @@
22
23
  ```
23
24
  と書いて日付範囲の指定なしで該当する日付のカウントをとるところまではできておりますが、日付の連番の仮想テーブルの作成とleft join をruby表現できず、以下の通りsqlを生で書いて対応しております。
24
25
  解決策が分かる方はよろしくお願いします。
25
- なお、SQLでは以下のように書いてます。
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.RailspostgereSQLを使った場合のメソッドの書き方
42
43
   実際にrailsに書くと以下のような感じとなりました。
43
44
   event.rb
44
45
  ```