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

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

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

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

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

1回答

311閲覧

has_many_through関連付けされているモデルのレコードの値が取得できない

widget11

総合スコア221

Ruby on Rails 5

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

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2019/03/17 07:55

以下のように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関連付けされてるからダメなのでしょうか?

よろしくお願い致します

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

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

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

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

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

guest

回答1

0

ベストアンサー

applicant_idをIDに持つApplicantレコードに紐づくWorkworknameを取得するのであれば

ruby

1workname = Applicant.find_by(id: applicant_id).work.workname

で取得できると思います。

投稿2019/03/18 07:14

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

widget11

2019/03/18 18:46

ご回答ありがとうございます!うまく動きました。 しかし分からないことが一つあります。 上のコードで Applicant.all.includes(:work).where(applicant_id: applicant_id).column('workname') と僕は書いています。 これはなぜ動かないのでしょうか?自身が意図したこととしては、Applicantテーブルの全件を取ってきてそれとリレーションのあるworkテーブルにinclude(内部結合に近いんですかね?)した後、結合テーブルの中で引数から渡されたapplication_idを条件検索し、そのカラムを指定したのですが、、、 その他Applicant.includes(:work)等色々試したのですがincludeがいまいちうまくいきません。なぜ上手く動かなかったのでしょうか。。。
退会済みユーザー

退会済みユーザー

2019/03/19 04:17

Applicant.includes(:works)であれば動くと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問