質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

1回答

1910閲覧

Rails 中間テーブルのレコード数で並び替えて取得

may88seiji

総合スコア79

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2020/04/05 16:37

編集2020/04/06 01:23

Rails DBからの取得で下記詰まっています。
助言がいただけると幸いです。

###前提

  • Rails
  • Active Record
  • 表示ページ
    主催者(ホスト)詳細画面 開催イベント一覧を表示
  • 開催イベントはゲストからストックされる
  • ホスト開催イベント一覧をゲストからのストック数順で表示したい
  • ER図
| 1 < 多 Hosts|-< Events|-< Stocks >-|Guests Stocks が中間テーブル event_id と guest_id が記録される

###実現したいこと

  • 主催者(ホスト)詳細画面にて
  • 中間テーブルのevent_id をgroup して guest_id の数の多い順に並べる
  • stockされた数を表示したい

###試したこと

ruby

1host_id = params[:host_id] 2host_events = Host.find(host_id).events.pluck(:id) 3Event.where(id: host_events).joins(:stocks).group(:event_id).order('count(guest_id) desc')
  • Eventsテーブルのレコードを該当ホストのものに絞る
  • その上でstocksに結合
  • .group(:event_id)でまとめる
  • .order('count(guest_id) desc') で並び替え

追記1

上記で並び替えた一覧の取得ができました。
あとはストック数を取得して表示になります。

追記2

試したことのコードに count をつけることで id と ストック数を取得できました。
ワンライナーでできたらと思うのでもう少し調べてみます。

なければそのまま自己解決にします。

助言いただけると幸いですmm

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

ruby

1host_id = params[:host_id] 2host_events = Host.find(host_id).events.pluck(:id) 3Event.where(id: host_events).joins(:stocks).group(:event_id).order('count(guest_id) desc')

投稿2020/04/06 02:19

may88seiji

総合スコア79

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問