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

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

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

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

Q&A

解決済

1回答

535閲覧

railsでグループ毎に投稿をいいね順に並べる

chanren_iiii

総合スコア11

Ruby on Rails

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

0グッド

0クリップ

投稿2020/05/20 13:57

好きなアーティストについて語り合う掲示板を作っています。
アーティスト(=artist)毎に良いところ(=charm)を書いて投稿し、その投稿をいいね順(=good)に上から3つならべようとしているのですがうまくいきません。

ruby '2.6.5'
rails '5.2.4.1'
sqlite3

###「完成形」           
######artist1
artist1かっこいい
いいね6
artist1は最高!
いいね4
artist1のグルーヴ感半端ない!
いいね2 
######artist2
artist2の〇〇いいね!
いいね5
artist2はこの先トップになるだろう
いいね3
artist2は何度聞いても飽きないね
いいね1 
###「現状」
######artist1
artist1かっこいい
いいね6
artist2の〇〇いいね!
いいね5
artist1は最高!
いいね4

  
######artist2
artist1かっこいい
いいね6
artist2の〇〇いいね!
いいね5
artist1は最高!
いいね4

artist毎のcharmではなく、全てのcharmの中でいいねの多い順番に表示されてしまいます。
わかりにくい文章ですが、どなたかご協力よろしくお願いします。

artists_controller.rb def index @artists = Artist.all end

artist.rb def charm_ranks return Charm.find(Good.group(:charm_id).order('count(charm_id) desc').limit(3).pluck(:charm_id)) end

html

1 <% @artists.each do |artist| %> 2 <div class="list-item"> 3 <div class="list-header"> 4 <div class="artist-name"> 5 <h3><%= link_to(artist.name, "/artists/#{artist.id}/show") %></h3> 6 </div> 7 </div> 8 9 <div class="artist-charm"> 10 <% if artist.charms %> 11 <% artist.charm_ranks.each do |charm| %> 12 <div class="charm-list"> 13 <div class="writer-name"> 14 <%= link_to("/users/#{charm.user.id}/show") do %> 15 <span class="fas fa-user-circle"></span> 16 <span><%= charm.user.name %></span> 17 <% end %> 18 </div> 19 20 <div class="charm-content"> 21 <%= link_to(charm.content, "#") %> 22 </div> 23 24 <div class="good"> 25 <% if @current_user %> 26 <span>いいね!</span> 27 <div id="good-<%= charm.id %>" class="good"> 28 <%= render partial: "goods/good", locals: {charm: charm} %> 29 </div> 30 <% else %> 31 <span>いいね!</span> 32 <div class="good"> 33 <i class="far fa-thumbs-up"></i> 34 <%= charm.good_count %> 35 </div> 36 <% end %> 37 </div> 38 </div> 39 <% end %> 40 <% end %> 41 </div> 42 </div> 43 <% end %>

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

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

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

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

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

guest

回答1

0

ベストアンサー

artist.charm_ranksの実装で、抽出条件としてselfのartistを絞り込んでいないからだと思います。

投稿2020/05/20 14:19

etsuhisa

総合スコア416

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

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

chanren_iiii

2020/05/21 10:28

ありがとうございます。そういうことでしたか。しかしその方法がよく分かりません…。
etsuhisa

2020/05/21 13:30

Goodを、Charmのarticle_idで絞ったidを使ってwhereで絞るんだと思います。間違っていたらすみません。 Charm.find(Good.where(charm_id: Charm.where(article_id: self.id).pluck(:id)).group~
chanren_iiii

2020/05/24 11:35

この通りにやったら上手くいきました!! この調子で開発頑張っていきます。ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問