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

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

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

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

Q&A

解決済

1回答

691閲覧

left_joinsで結合したテーブルをselect項目に含めたい

pecchan

総合スコア558

Ruby on Rails 5

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

0グッド

0クリップ

投稿2020/08/15 06:20

rails5.2です。

発行したいSQLは下です。
roomsテーブルにleft joinしたmessagesテーブルのtextというカラムも、select項目に含めたいです。

SQL

1 select r.id, user1_id, user2_id, m.text, from rooms as r 2 left join lastest_messages as lm on r.id = lm.room_id 3 left join messages as m on lm.message_id = m.id 4 where (user1_id =1 OR user2_id = 1) AND status = 't' ;

rails側で以下のようにしましたが、

ruby

1@rooms = Room.select('Rooms.*, text') 2 .where(user1_id: current_user) 3 .or(Room.where(user2_id: current_user)) 4 .where(status: true) 5 .left_joins(:lastest_messages) 6 .left_joins(:messages) 7 .paginate(page: params[:page])

というエラーで怒られました。

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

.select('Rooms.*, text')
を外すとエラーになりませんが、そうするとroomsしか取れずtextが取れません。

各モデルは以下のようにしてます。

ruby

1class Room < ApplicationRecord 2 has_many :messages 3 has_many :lastest_messages 4 belongs_to :user1, class_name: 'User' 5 belongs_to :user2, class_name: 'User' 6 7end 8

ruby

1class LastestMessage < ApplicationRecord 2 belongs_to :room 3 belongs_to :message 4end 5

ruby

1class Message < ApplicationRecord 2 belongs_to :user 3 belongs_to :room 4 belongs_to :lastest_messages 5 6end 7

どうすればjoinしたmessagesテーブルのtextも取れるでしょうか?

分かる方教えていただけないでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

多分
.or(Room.select('Rooms.*, text').where(user2_id: current_user))

投稿2020/08/15 09:11

winterboum

総合スコア23366

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

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

pecchan

2020/08/15 12:15

いつも有難う御座います( ;∀;)!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問