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

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

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

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

Ruby on Rails

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

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

965閲覧

joinした後のアソシエーションについて

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby

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

Ruby on Rails

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

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2021/09/24 03:22

取得したいもの

ユーザがいいねしたMessageのユーザーを取得したい

試したこと

1.Message.where(timeline_id: PostBadge.where(timeline_id: Timeline.where(timelinable_id: Message.joins(:timeline).map(&:id)).map(&:timeline_id)).map(&:timeline_id)) 2.Message.where(timeline_id: user.likes.joins(:timeline).map(&:timeline_id))

当たり前なのですがMessageにはtimeline_idがないというエラーがでました。
joinしたあとにuser.likes.joins(:timeline).messageのように取得したいのですが
何か方法があったら教えていただきたいです。

該当のソースコード

ruby

1 2#メッセージテーブル 3create_table "messages",charset: "utf8mb4", force: :cascade do |t| 4 t.integer "user_id", null: false 5 t.string "message", limit: 10000 6end 7 8#いいねテーブル 9create_table "likes",charset: "utf8mb4", force: :cascade do |t| 10 t.bigint "timeline_id", null: false 11 t.bigint "like_id", null: false 12 t.integer "user_id",null: false 13end 14 15#タイムラインテーブル 16create_table "timelines",charset: "utf8mb4", force: :cascade do |t| 17 t.bigint "timelinable_id" 18end 19

ruby

1 2class Timeline < ApplicationRecord 3 belongs_to :timelinable, polymorphic: true 4 has_many :likes 5 belongs_to :message, foregn_key: timelinable_id, optional: true 6end 7 8class Like < ApplicationRecord 9 belongs_to :timeline 10 belongs_to :user 11end 12 13class Message < ApplicationRecord 14 belongs_to :user 15 has_one :timeline, as: :timelinable 16end 17 18class User < ApplicationRecord 19 has_many :messages 20 has_many :likes 21end 22

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

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

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

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

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

winterboum

2021/09/24 09:43

「いいねしたMessageのユーザーを取得したい」 のですか? 「user.likes.joins(:timeline).messageのように取得したい」messageを取得したいのですか?
退会済みユーザー

退会済みユーザー

2021/09/24 12:21 編集

いいねしたMesssageを取得したいです。Messageがとれればテーブルの中にuser_idがあり、ユーザを取得できると思っています。
guest

回答1

0

ベストアンサー

Messageが不可解なmodelです。
これは LikeにつくMesageではなく、
Userにつくものなのですね?

User(投稿者) 1ー多 Message 1ー1 Timeline 1ー多 Like 1ー1 User 1ー1
という関係ですね?
ということは Likeした人を取り出すためにその人のMessageを取り出すには、Likeした人を取り出す必要があるので、、、、
LikeしたUserを取り出す方が良いように。
いっぺんにできるかな、、、
User.joins(likes: {timeline: {message: :user}}) .where(user: 投稿者)

でいけるかなぁ。あまり自信なし。

user.messages.map{|message| message.timeline.likes} .map{|like| like.user}.flatten
DBの負担かかるけど、これかな。

user.messages.includes(timeline: {likes: :user} .map{|message| message.timeline.likes} .map{|like| like.user}.flatten
とすればDBの負担減るかも。自信なし

投稿2021/09/24 15:11

winterboum

総合スコア23416

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

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

退会済みユーザー

退会済みユーザー

2021/09/25 07:55

ありがとうございます! Likeとユーザーは多対1となるのですがこの場合はどうなりますでしょうか????
winterboum

2021/09/28 08:45

{likes: :user} なのでそこはカバーできてると思いますがやってみてください
退会済みユーザー

退会済みユーザー

2021/10/05 05:46

一旦できました。 ご対応ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問