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

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

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

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

1575閲覧

railsの並び替えで、デフォルトはいいねの多い順、リンクをクリックすることで新着順と評価の高い順、いいねの多い順にそれぞれソートしたい

sakurasakanai

総合スコア1

Ruby on Rails 6

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

1グッド

0クリップ

投稿2022/11/04 03:47

編集2022/11/04 04:09

railsの並び替えで、デフォルト(一覧画面に来た時)はいいねの多い順、リンクをクリックすることで新着順と評価の高い順、いいねの多い順にそれぞれソートしたいです。
ビューとコントローラの記述で詰まっています。
初学者ですがよろしくお願いいたします。

Bookモデルには評価(star)カラムはありますが,いいねのカラムは作ってないです。

rails

1 2 <div class='col-md-8 offset-md-1'> 3 <h2>Books</h2> 4 <%= link_to "新しい順", books_path(sort_create: "true") %> | 5 <%= link_to "評価の高い順", books_path(sort_star: "true") %> | 6 <%= link_to "いいねの多い順", books_path(sort: 'favorite DESC') %> 7 <%= render 'index', books: @books %> 8 </div> 9 10 11``` controller 12 def index 13 @books = Book.most_favorite.order("favorites_count DESC").select("books.*") 14 if params[:sort_create] 15 @books = Book.latest 16 elsif params[:sort_star] 17 @books = Book.star 18 end 19 @user=current_user 20 @book=Book.new 21 end 22 23```model 24 scope :latest, -> {order(created_at: :desc)} 25 scope :star, -> {order(star: :desc)} 26 27 has_many :favorites, dependent: :destroy 28 has_many :week_favorites, -> { where(created_at: ((Time.current.at_end_of_day - 6.day). 29 at_beginning_of_day)..(Time.current.at_end_of_day)) }, class_name: 'Favorite' 30 31 scope :most_favorite, -> { left_joins(:favorites).select(:id, "COUNT(favorites.id) AS favorites_count").group(:id) }
sakurasakanai👍を押しています

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

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

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

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

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

guest

回答1

0

自己解決

if分でわけることで解決できました。

投稿2022/11/04 04:15

sakurasakanai

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問