以下のようにwork(仕事)とユーザー(サービス利用者)の関係がN対Nになっているテーブル(1人のユーザーは多数の仕事を持ち得る、1つの仕事は多数のユーザーを持ち得る)があり、中間テーブルをその仕事に対するApplicant(応募者)にしているとします。
Work(仕事)モデル
- id(integer)
- workname(string)
- cost(integer)
Applicant(応募者)モデル
- id(integer)
- work_id(references)
- user_id(references)
User(ユーザー)モデル
- id(inetger)
- name(string)
リレーション
class Work < ApplicationRecord has_many :user, through: :applicant end class User < ApplicationRecord has_many :work, through: :applicant end class Applicant < ApplicationRecord belongs_to :work belongs_to :user end
この時例えば、
候補者モデルから、Workテーブルの名前を参照したい場合
#引数application_idにはparamsで取得してくる数字が入ってくるとします def workname(applicant_id) workname = Applicant.all.includes(:work).where(applicant_id: applicant_id).column('workname') end
としてますが、workモデルの属性worknameを取ってこれません。
クエリを見るとどうやらincludeに値する結合クエリが発行されていないようなのですが。。。。。
has_many_through関連付けされてるからダメなのでしょうか?
よろしくお願い致します
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/03/18 18:46
退会済みユーザー
2019/03/19 04:17