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

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

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

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

Ruby on Rails

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

Q&A

解決済

2回答

4863閲覧

[Ruby on Rails]関連する孫モデル一覧の取得方法について

ihibiki

総合スコア7

Model

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

Ruby on Rails

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

0グッド

0クリップ

投稿2016/04/13 10:03

編集2016/04/14 06:05

###前提・実現したいこと
railsのモデル関連付けで孫に位置するモデル一覧を簡潔に取得する

###具体的な状況
モデルとして下記を考えたとき、メディア運営者オブジェクトから、関連する広告出稿依頼一覧を取得する良い方法はありますでしょうか?
併せて、どう関連付けを設定すれば良いかもお答えいただけますと幸いです。
※現状考えている関連付けも合わせて記載しております

  • メディア運営会社

  • has_many メディア

  • メディア

  • belongs_to メディア運営会社

  • has_many 広告出稿依頼

  • has_many 広告出稿者 through 広告出稿依頼

  • 広告出稿依頼

  • belongs_to メディア

  • belongs_to 広告出稿者

  • 広告出稿者

  • has_many 広告出稿依頼

  • has_many メディア through 広告出稿依頼

よろしくお願い致します。

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

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

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

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

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

suzukis

2016/04/14 05:13

質問を文字通りに読む範囲だと「広告出稿依頼」が「メディア運営会社」に紐付けられるのか「メディア」に紐付けられるのかは完全にアプリケーションの仕様の話なので、人に聞いても答えられない内容だと思います。「こう紐付けをするとこういう時にこういう問題が起きる」「こういう操作をする方法がわからない」とか実際の具体的な疑問があるのではないでしょうか?
ihibiki

2016/04/14 06:07 編集

ご指摘ありがとうございます。仰る通り、途中で思考停止しておりました。 質問内容の修正を致しましたので、もし良ろしければご回答頂けますと幸いです。 よろしくお願い致します。
guest

回答2

0

ベストアンサー

メディア運営会社 - has_many メディア - has_many 広告出稿依頼 through メディア

今まで普通にこういうリレーションを設定してたのですが、回答書いてる途中に違和感に気付いて確認してみました。

こういう風に、has_many :throughがhas_manyのネストのショートカットにもようです。Rails guideのhas_many :throughの説明の後ろの方です。

運営会社.広告出稿依頼を実行した時のSQLはこうなりました

SQL

1SELECT "広告出稿依頼".* FROM "広告出稿依頼" INNER JOIN "メディア" ON "広告出稿依頼"."メディア_id" = "メディア"."id" WHERE "メディア"."運営会社_id" = ?

投稿2016/04/15 09:07

suzukis

総合スコア1449

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

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

0

モデル設計は一面的な判断は出来ないので、
例だけだと何ともアドバイスできませんが、
例示された設計ならば、以下のようなArelで取得可能です。

Ruby

1# Media メディア 2# MediaOperator メディア運営会社 3# AdRequest 広告出稿依頼 4# AdRequester 広告出稿者 5media_table = Media.are_table 6media_op_table = MediaOperator.arel_table 7ad_req_table = AdRequest.arel_table 8j_source = ad_req_table.join(media_table, Arel::Nodes::OuterJoin) 9 .on(ad_req_table[:media_id].eq(media_table[:id]) 10 .join(media_op_table, Arel::Nodes::OuterJoin) 11 .on(media_table[:media_operator_id].eq(media_op_table[:id])).join_source 12AdRequest.joins(j_source).where(media_op_table[:id].eq(media_operator_id))

モデルの関連が複雑でも、設計に矛盾がなければ、取得する方法はあるはずなので、
取得方法云々を設計の段階で考えるのではなく、
矛盾なく美しくすることを心がけて設計する方が良いかと。
(Railsを使う時点で、速度問題や容量などをカリカリに詰める必要もないと思うので)

投稿2016/04/14 07:46

rifuch

総合スコア1901

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

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

ihibiki

2016/04/14 16:06

ご回答ありがとうございます。 取得方法も然ることながら、根本的な姿勢に関するご指摘大変助かります。 まずは矛盾のない設計に焦点を当てて考えるよう心がけます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問