質問するログイン新規登録
Ruby on Rails 5

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

Ruby

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

Q&A

解決済

1回答

1141閲覧

rails モデル名.where(created_at: Time.current.all_month)で今月投稿されたデータを取得したいが先月のデータも取得してしまう。

0.taiga.7

総合スコア2

Ruby on Rails 5

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

Ruby

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

0グッド

0クリップ

投稿2022/02/12 05:07

編集2022/02/12 09:24

0

0

前提・実現したいこと

SNS系のアプリを作成しております。
いいね数の多い順にランキング機能を実装しています。
その際に月間ランキングで、今月投稿された投稿の中でいいね数が多い順にランキングにしたいと考えております。(今であれば2月に投稿された内容のみ)

発生している問題・エラーメッセージ

先月投稿された投稿にいいねをすると、今月投稿されたものと認識されてしまいランキングページに表示されてしまいます。 例) ・現在が1月と仮定 1月に新規投稿、1月中いいね数0、1月のランキングに表示されない→正常(確認済み) 1月に新規投稿、1月中いいね数10、1月のランキングに表示される→正常(確認済み) ・現在が2月と仮定 1月に新規投稿、1月中いいね数10、2月中いいね数0、2月のランキングに表示されない→正常(確認済み) 1月に新規投稿、1月中いいね数10、2月中に1回以上いいね、2月のランキングに表示される→正常でない(今回の問題点) ※いいねを取り消すとランキングからも消えます。 2月の場合は、2月に新規投稿された投稿のいいね数でランキング表示を行いたいです。 posts_controller.rbのrankingアクション内の@posts_good_rankingで問題が起きております。

該当のソースコード

posts_controller.rb

1def ranking 2 @posts_pv_ranking = Post.where(created_at: Time.current.all_month).order(impressions_count: 'DESC').limit(4) 3 @posts_good_ranking = Post.find(Like.group(:post_id).where(created_at: Time.current.all_month).order('count(post_id) DESC').limit(4).pluck(:post_id)) 4 @date1 = Date.current.strftime('%m') 5end 6 7def pv_ranking 8 @posts_pv_ranking = Post.where(created_at: Time.current.all_month).order(impressions_count: 'DESC').page(params[:page]).per(8) 9 @date1 = Date.current.strftime('%m') 10end 11 12def good_ranking 13 @posts_good_ranking = Post.find(Like.group(:post_id).where(created_at: Time.current.all_month).order('count(post_id) DESC').pluck(:post_id)) 14 @posts_good_ranking = Kaminari.paginate_array(@posts_good_ranking).page(params[:page]).per(8) 15 @date1 = Date.current.strftime('%m') 16end

ranking.html.erb

1<div class="container"> 2 <h4>グッド!!が多い投稿(<%= @date1 %>月)</h4> 3 <div class="row"> 4 <%= render "good_ranking", posts_good_ranking: @posts_good_ranking %> 5 </div> 6 <div class=" row d-flex justify-content-end ranking-list"> 7 <%= link_to "一覧で見る", posts_good_ranking_path %> 8 </div> 9 <h4>閲覧数が多い投稿(<%= @date1 %>月)</h4> 10 <div class="row"> 11 <%= render "pv_ranking", posts_pv_ranking: @posts_pv_ranking %> 12 </div> 13 <div class=" row d-flex justify-content-end ranking-list"> 14 <%= link_to "一覧で見る", posts_pv_ranking_path %> 15 </div> 16</div>

_goodranking.html.erb

1<% posts_good_ranking.each do |post| %> 2 <div class="col-lg-3 d-flex flex-column postranking"> 3 <div class="ranking-user-name"> 4 <%= link_to user_path(post.user.id) do %> 5 <%= attachment_image_tag post.user, :profile_image, size: '50x50', fallback: "no_image.jpg" %> 6 <%= post.user.name %> 7 <% end %> 8 </div> 9 <div> 10 <%= post.title %> 11 </div> 12 <div class="mb-auto ranking-post"> 13 <% post.post_images.first(1).each do |image| %> 14 <%= link_to post_path(post.id) do %> 15 <%= attachment_image_tag image, :image, class: "ranking_image" %> 16 <% end %> 17 <% end %> 18  </div> 19  <div> 20   <i class="fas fa-thumbs-up"></i> 21   <%= post.likes.count %> 22   <i class="far fa-clock clock-icon"></i> 23 <%= time_ago_in_words(post.created_at) %>前 24  </div> 25 </div> 26<% end %>

試したこと

posts_controller.rb

1def ranking 2 @post = Post.where(created_at: Time.current.all_month) 3 @posts_good_ranking = @post.find(Like.group(:post_id).order('count(post_id) DESC').limit(4).pluck(:post_id))

まず上記のように最初に今月作成されたデータだけを取得しその上でいいね数を数えて並べるようにしましたが下記エラーが表示され解決方法がわからない状態です。
ActiveRecord::RecordNotFound in PostsController#ranking
Couldn't find all Posts with 'id': (1, 2, 3, 4) [WHERE "posts"."created_at" BETWEEN ? AND ?] (found 1 results, but was looking for 4).

どのようにしたら、先月投稿された投稿にいいねをしても、今月投稿されたものと認識されず、今月新規投稿された投稿だけでランキング機能を実装できますでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

わかりにくい質問です、
view が ranking.html だから action ranking だろうとはおもいますが 問題が起きているのが
@posts_pv_ranking なのか @posts_good_ranking なのか が明記されていないのでわかりにくいのです。

code をみると 前者では起きそうにない、後者だけ起きている、と思われるのでその線で
Post.find(Like.group(:post_id).where(created_at: Time.cu ..... とあります。
これは、「今月 Like された」 Post を拾ってます。のでそういう動作になります。
Post.where(created_at: 。。。).find( ) にしてください。find ではなく where(id: ...) の方が例外立たないからよいかも。
今月Postされたもので、Like されたもの を拾うのでしたら、 Likeは今月しかないですから、Like に created_at の条件は不要です。
入れても良いけど。

投稿2022/02/12 08:51

winterboum

総合スコア23669

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

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

0.taiga.7

2022/02/12 09:22

回答いただきありがとうございます。 質問がわかりにくく申し訳ありません。 おっしゃる通り@posts_good_rankingで問題が起きております。 ご教示いただいたように、Post.where(created_at: 。。。).find( )としたところ自身で試したことで記載したのと同じエラーが発生しました。 LIKEのcreated_atは削除しました。 findではなくwhere(id: ...)に変更したら今月の投稿のみ表示することができました。 しかし、こうしたことで1番いいね数の多い投稿しか取得することができず1件のみの表示になりました。 LIKEにcreated_atを入れ試したところ表示は2つに増え、消すと1つになります。 規則性がわかりません。 やりたいこととしては、今月の投稿のいいね数が多い順に4つ取り出すことです。
0.taiga.7

2022/02/12 09:32

すみません。 .limit(4)をwhere(id: ...)の外に記述したらうまくいきました。 大変助かりました。 ありがとうございます。 ちなみに、find()の時とwhere(id: ... )の時でどうして違いが生まれたのでしょうか?
winterboum

2022/02/12 10:51

find は hit しないと 例外となります where はhit しないと 空の配列(のようなもの)が帰ります
0.taiga.7

2022/02/13 09:04

今回の場合は例外になっていたんですね。 ありがとうございます!
winterboum

2022/02/13 09:30

ActiveRecord::RecordNotFound in PostsController#ranking これが例外 ActiveRecord::RecordNotFound が発生した、というメッセージです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問