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

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

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

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

Q&A

解決済

1回答

2811閲覧

【Ruby on Rails 】関連モデルのカラムで並び替えをしたい

pecchan

総合スコア555

Ruby on Rails

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

0グッド

0クリップ

投稿2017/05/12 07:52

編集2017/05/13 00:47

感想一覧があり、表示項目は、
社員名、感想です。
感想モデルは以下のように社員idを持ちます。

【感想モデル】
フィールド
・id
・employee_id
・impression

Railsのアソシエーションのおかげで感想一覧にて
社員名を表示する所までは出来ました。

一覧上で自モデルのフィールドである「感想」をクリックで、並び替えできますが、
別モデルのフィールドである「社員名」によるソートの方法が分かりません。

調べると「includes」という機能があるようで、
以下のように感想モデルに追加しましたが、違うようです。

感想モデル

Ruby

1 2class Impression < ApplicationRecord 3 4 belongs_to :employee 5 6 self.includes(:employee) 7end 8

このようにビュー側にて自モデルのカラムだけなく、関連先のカラムをクリックで、ソートしたい場合どうするのでしょうか?
さらに、関連先がある場合も可能でしょうか?※社員マスタと関連した資格マスタのカラム等

どうぞ宜しくお願い致します。

社員モデル

Ruby

1class Employee < ApplicationRecord 2 3 has_many :impressions 4 5end 6 7

感想一覧ビュー

RUby

1 2<thead> 3 <tr> 4 5 <th><%= sortable "emp_name", "社員" %></th> 6 <th><%= sortable "impression", "感想" %></th> 7 </tr> 8 </thead> 9 <% @impression.each do |impression| %> 10 <tbody> 11 <tr> 12 13 <td><%= impression.employee.emp_name %></td> 14 <td><%= impression.impression %></td> 15 </tr> 16 </tbody> 17 <% end %> 18

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

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

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

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

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

guest

回答1

0

ベストアンサー

ここの「INCLUDE/JOINした他のテーブルのカラムでORDER BY」でしょうか?

投稿2017/05/12 09:20

yoorwm

総合スコア1305

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

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

pecchan

2017/05/12 13:19

yoorwm様 有難う御座います。 理想はcontrollerではなく、モデルで設定しておき、 ビューのクリックで昇順・降順を切り替えたいのです。
pecchan

2017/05/16 02:50

yoorwm様 有難う御座いました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問