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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

1回答

1498閲覧

Ruby on Rails 表示順の変更に関して

lapi

総合スコア58

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

3クリップ

投稿2017/03/20 07:40

###前提・実現したいこと
Rails4で作成。

表示順の変更に関して、
2chのスレッド一覧のように、表示順をスレッドにコメントがあったら上位に表示させるといった場合、どのようにするのでしょうか?

作成方針というか、概要を教えて頂けると嬉しいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ThreadモデルとCommentモデルを用意する
Commentモデルのテーブルにはカラムとしてthread_idを持たせてあり、Threadモデルのテーブルのidとアイソレーションしてある
Thread has many comments
comment belongs to thread の関係
単純にコメント数が多い順にソートするのであれば

ruby

1comments = Comment.group(:thread_id).order('count_thread_id DESC').count(:thread_id)

として、コメント数が多いスレッドのidを順番に(配列として)とってきて、

ruby

1@threads = comments.map{ |id| Thread.find(id) }

としてやれば、@threadsには、スレッドのインスタンスがコメント数の多い順に格納される

投稿2017/03/20 19:24

sny_shinya

総合スコア21

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

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

lapi

2017/03/20 23:57

ご回答ありがとうございます。 orderの使い方がまだまだ理解不足だったので勉強してみます。 あと、コメント数が多い順にソートするのではなく コメントがされたら上位に表示させるといった場合は orderのソート式を変えれば可能でしょうか?
sny_shinya

2017/03/21 04:09

うまくいかなければ、またおっしゃってください コメントがされたとき上位に表示させる場合は、されたコメントの生成日時を取得して、その生成日時で、ならべかえる必要があると思いますので、また違った書き方になります すぐ具体例を提示できなくて申し訳ないです
lapi

2017/03/21 04:24

ありがとうございます。 コメントの生成日時を取得して並べ変えるといいんですね! 試行錯誤して挑戦してみます! うまくいかなかったときは新しく質問を立てますので、機会があればまたご教授いただけると嬉しいです。
sny_shinya

2017/03/21 04:57

僕にわかる範囲であれば、いくらでもご質問ください よろしくお願いします
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問