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も取れるでしょうか?
分かる方教えていただけないでしょうか?
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/08/15 12:15