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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

1回答

4675閲覧

RailsのActiveRecordの内部結合(whereとorとjoinsの使い方)

innjera

総合スコア132

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

0クリップ

投稿2017/05/11 14:45

編集2017/05/11 14:47

以下4つのモデルが関連つけられている際に、@messages = Message.where(deleted: false, user_id: current_user_id).or(Message.where(deleted: false, lesson_id: @adviser.lessons.ids))で呼び出せるMessagejoinを用いて改善したいと考えています。

@messages = Message.where(deleted: false, user_id: current_user_id).or(Message.joins(:adviser))と記載したところ、

Relation passed to #or must be structurally compatible. Incompatible values: [:joins]

といったエラーが出てしまいました。解決策わからず、お分かりの方、ご教示頂けますと助かります。

ruby

1has_one :adviser 2has_many :messages

ruby

1#adviser 2has_many :lessons

ruby

1#message 2belongs_to :lesson 3belongs_to :user 4has_one :adviser ,through: :lesson

ruby

1#lesson 2belongs_to :adviser 3has_many :message

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

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

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

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

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

guest

回答1

0

ベストアンサー

英語の勉強の時間です。
エラーメッセージを翻訳にかけると
「orに渡される関係は、構造的に互換性がなければなりません。互換性のない値:[:join]」

つまりorの中のモデルのリレーションと外のモデルリレーションには同じjoin
がかけられていなくてはいけないということです。
つまり

ruby

1Message.joins(:adviser).where(deleted: false, user_id: current_user_id).or(Message.joins(:adviser).where(:advisers=>{:id=>@adviser_id}))

一応、join先のモデルにwhere をするやり方が、悩むところなので注意してください。

ruby

1mess=Message.joins(:adviser) 2mess.where(deleted: false, user_id: current_user_id).or(mess.where(:advisers=>{:id=>adviser_id}))

ともかけますし、これの方が軽いかな?

ちなみに
Relation passed to #or must be structurally compatible. Incompatible values: [:joins]
をそのまま検索をかけると、日本語で、解決策が出てきます。
まさにググレカス

投稿2017/05/12 05:39

編集2017/05/12 05:42
moke

総合スコア2241

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

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

innjera

2017/05/29 23:29

返答遅くなってしまい大変申し訳ありません、有難うございます!解決しました&大変勉強になりました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問