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

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

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

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

Ruby on Rails

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

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

Q&A

0回答

950閲覧

検索結果をbookmark順、平均評価の高い順に並び替えたい

nao0725

総合スコア5

Ruby

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

Ruby on Rails

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

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

0グッド

0クリップ

投稿2021/08/13 02:54

【解決したい課題】
検索結果によって順序を並び替えたい
(評価、ブックマーク数)

【現状】(エラー内容)
homeで新着、ブックマーク数、評価順に並んでいる状態
HomesControllerで下記のように定義したがerrorが出ており、解決に至らない

homes_controller.rb

1class Public::HomesController < ApplicationController 2 3 def search 4 @article = Article.new 5 @articles = Article.search(params[:keyword]) 6 .page(params[:page]).per(10) 7 @bookmarks = Article.search(params[:keyword]) 8 .find(Bookmark.group(:article_id) 9 .order(Arel.sql("count(article_id) desc")) 10 .pluck(:article_id)) 11 @reviews = Article.find(Comment.group(:article_id) 12 .order(Arel.sql("avg(rate) desc")) 13 .pluck(:article_id)) 14 end 15 16end

下記error文
→意味は理解できたが、どのように解消すべきかわからない状態

ActiveRecord::RecordNotFound in Public::HomesController#search Couldn't find all Articles with 'id': (1, 2, 3) [WHERE (title LIKE('%仕事%') OR body LIKE('%仕事%') OR sub_title LIKE('%仕事%') )] (found 0 results, but was looking for 3).

【該当ソースコード】

home.html.erb

1<div class="content-area"> 2 3 <!--新規投稿順--> 4 <div class="content show"> 5 <% @articles.each do |article| %> 6 <%= render "public/articles/index", article: article %> 7 <% end %> 8 <div class = "pagination-sm"> 9 <%= paginate @articles %> 10 </div> 11 </div> 12 13 <!--ブックマーク数順--> 14 <div class="content"> 15 <% @bookmarks.each.with_index(1) do |article, i| %> 16 <%= render "public/articles/index", article: article %> 17 <% end %> 18 </div> 19 20 <!--評価の高い順--> 21 <div class="content"> 22 <% @reviews.each.with_index(1) do |article, i| %> 23 <%= render "public/articles/index", article: article %> 24 <% end %> 25 </div> 26 </div> 27</div> 28

article.rb

1class Article < ApplicationRecord 2 3 belongs_to :user 4 has_many :bookmarks, dependent: :destroy 5 has_many :comments, dependent: :destroy 6 7 #複数検索できるように設定 8 def self.search(search_word) 9 Article.where(["title LIKE(?) OR body LIKE(?) OR sub_title LIKE(?) ", 10 "%#{search_word}%", "%#{search_word}%", "%#{search_word}%"]) 11 end 12 13end 14

【対策と自分の考え】
対策は現状に挙げた通り
その他、.search(params[:keyword])の場所を変更しながらerror解消に望みましたが、NameErrorが発生し前に進まない状態です。

アドバイスいただけると幸いです。
ご確認をよろしくお願い致します。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問