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

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

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

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

SQL

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

解決済

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

sakurasakanai
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回答

1グッド

0クリップ

379閲覧

投稿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👍を押しています

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

回答1

0

自己解決

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

投稿2022/11/04 04:15

sakurasakanai

総合スコア1

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Ruby on Rails 6

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

SQL

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