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

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

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

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

Ruby on Rails 6

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

include

あるファイルで定義された関数や処理を、別のファイル上でも使用できるようにするプロセスをincludeと呼びます。

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

968閲覧

テーブルをまたいでデータを取り出せずに困っています。

tomtomtomtom

総合スコア563

Ruby

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

Ruby on Rails 6

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

include

あるファイルで定義された関数や処理を、別のファイル上でも使用できるようにするプロセスをincludeと呼びます。

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2020/08/02 12:26

編集2020/08/04 07:36

joinsでうまく取り出せません。

環境

ruby 2.5.1

rails 6.0.3.2
devise 4.7.2

アソシエーション

ruby

1userモデル 2 3 has_many:tags 4 has_many:group_users 5 has_many:groups,through: :group_users

ruby

1group_use中間モデル 2 3 belongs_to :group 4 belongs_to :user

ruby

1groupモデル 2 3 has_many:group_tags 4 has_many:tags,through: :group_tags 5 has_many:group_users 6 has_many:users,through: :group_users

ruby

1group_tag中間モデル 2 3 belongs_to :group 4 belongs_to :tag

ruby

1tagモデル 2 3 has_many:group_tags,dependent: :destroy 4 has_many:groups,through: :group_tags 5 belongs_to:user

maigationファイル内記述を簡単に説明

ruby

1user 2 3 # おそらく今回の件とは関係がないため割愛します。

ruby

1group_use 2 3 t.references :group, foreign_key: true 4 t.references :user, foreign_key: true

ruby

1group 2 3 # おそらく今回の件とは関係がないため割愛します。

ruby

1group_tag 2 3 t.references :group, foreign_key: true 4 t.references :tag, foreign_key: true

ruby

1tag 2 3 t.references :user, foreign_key: true

やりたいこと

ruby

1tags_controller.rb 2 3 def index 4 if user_signed_in? 5 @groups=Group.joins(:group_users).where(group_users:{user_id:current_user.id}) 6 @tags=Tag.joins(group_tags: :group_users).where(group_users:{user_id:current_user.id}) 7 end

上のrubyコードを御覧ください。まず、
@groupsはcurrent_user.idを利用し、group_usersを介してグループの情報を取得しています。
current_user.id → group_user → group_id → group
ここは成功しました。

次に
@tagsでcurrent_user.idを利用し、group_users、group_tagsを介してタグの情報を取得しようとしました。
current_user.id → group_users → group_id → group_tags → tag_id → tags
これに失敗しました。

current_userが所属するgroupが所有するtagをすべて取得したいと考えておりますがうまくいきません。
N+1問題対策のため、なるべくjoinを使用して解決したいです。

どなたかわかる方がいらっしゃいましたら、ご教授いただけたら幸いです。
誠に申し訳ありませんが、よろしくお願いいたします。

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

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

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

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

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

winterboum

2020/08/03 23:45

アソシエーションですが、どのmodelのcodeなのか笑らないんで、そこわかるようにしてください。 他のcodeも同じく。どのfileなのかわかるようにしてください
guest

回答1

0

ベストアンサー

関連が定義してあるので、
@groups = current_user.groups で採れますよ。

@tags = Tag.joins(:groups).where("groups.user_id = ?", current_user.id)
で行けるかと。
user_idはこの2つでは groupsにしかないので
@tags = Tag.joins(:groups).where(user_id: current_user.id)
でもいけてしまうかも。

投稿2020/08/04 08:12

winterboum

総合スコア23567

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

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

tomtomtomtom

2020/08/04 09:20 編集

ご解答誠にありがとうございます。 後日になりそうですが試してみたいと思います。 結果ご報告いたします^^ ありがとうございましたm(-_-)m
tomtomtomtom

2020/08/04 17:28

頂いたご解答でなんとかなりそうです!誠にありがとうございました! ベストアンサーにさせていただきます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問