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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

730閲覧

Ruby on Railsで自分の所属する全てのグループの投稿を全て表示させたい

atage517

総合スコア36

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/07/31 08:57

やりたいこと

自分が所属するグループ(ここではUnion)の全ての投稿をpost index で表示したいのですがどう考えてもできません。

自分が所属するUnionは2つあります。

1、自分が作成したUnion。 これはUnionのuser_id に @current_userのidが保存されています。
2、他人が作成したUnionに参加している場合。 この場合は中間テーブルであるUnion_user の user_id に @current_userの id が保存されています。

自分が所属するある一つのUnionに投稿されているPostを表示するのは以下で可能かと思います。

def posts_index @union = Union.find_by(id: params[:id]) @user = @union.user @posts = Post.where(union_id: params[:id]).order(created_at: :desc) end      <% @posts.each do |post| %> <div class="posts-index-item">   .   . <% end %>

しかし、自分が所属しているUnionが複数ある場合に全てのpostを表示させることができません。

やったこと

def index @user = User.find_by(id: @current_user.id) @unions = Union.where(user_id: @user.id).order(created_at: :desc) end <% @unions.each do |union| %> ← 自分が作成したUnion <div class="unions-index-item"> . . <% end %> <% @user.unions.each do |union| %> ← 他人が作成したUnion <div class="users-index-item"> . . <% end %>

以上のコードのようにして、自分が作成したUnion, 他人が作成したけど自分が所属するUnion index は表示できます。

そしてそのUnionsのポストを以下のように取り出そうとしてもうまくできません。

def user_posts_index @user = User.find_by(id: @current_user.id) @unions = Union.where(user_id: @user.id).order(created_at: :desc) end <% @unions.each do |union| %> <% post = Post.find_by(union_id: union.id)%> <div class="posts-index-item"> . . <% end %>

どうしたらできるでしょうか?

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

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

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

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

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

winterboum

2020/07/31 10:53

UnionとUserの関連定義を載せてください。 あと、予感として Unionの作成者はUnion_userには登録されていないのですね? Unionのownerとメンバーの管理は分けておいたほうが(作成者もUnionUserに登録する)この処理は楽になるなぁ、、と
atage517

2020/07/31 13:01

class Union < ApplicationRecord has_many :union_users has_many :users, through: :union_users accepts_nested_attributes_for :union_users end class User < ApplicationRecord has_many :union_users has_many :unions, through: :union_users end class UnionUser < ApplicationRecord belongs_to :user belongs_to :union end Unionの作成者はUnionのuser__idに登録していますね。 そして他人の作ったUnionに参加した時はUnionUser テーブルを中間テーブルとしてuser_idに登録しています。 @posts = Post.where(union_id: @user.unions.ids) @posts = Post.where(union_id: @unions.ids) で自分が作ったUnionのpost index 参加しているUnionのpost index を表示することができたのですが二つとも表示させることができないので今方法を探しています
guest

回答1

0

ベストアンサー

このケースは、Unionを作った本人も UserUnionに登録するのが一番簡単ですし、いろいろメリットもあります。
もしそうしてあれば
atageさんの
posts = Post.where(union_id: @user.unions.ids)(DBアクセス2回)
でも
posts = Post.joins(union: :users).where("users.id =?",@user.id)(DBアクセス1回)
でも取れます。

そうでない現状では
@posts = Post.where(union_id: @user.unions.ids) + Post.where(union_id: @unions.ids)
とか
@posts = Post.where(union_id: (@user.unions.ids + @unions.ids))
とかせざるを得ません。
現状では 4or3回のDBアクセスになり、そこもなんか気持ち悪いです

「union.user は『Unionを作った人』の意味だけ」にするのではだめですか?

投稿2020/07/31 23:40

winterboum

総合スコア23329

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

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

atage517

2020/08/03 01:10

すみません週末は忙しくて返信が遅れました。 いまwinterboumさんが書いたように @posts = Post.where(union_id: (@user.unions.ids + @unions.ids)) でやると自分が作成したUnionと自分が所属しているUnionの投稿全てを取り出すことができました。 + を使って複数の条件を組み合わせることがでいるとは知りませんでした!ありがとうございます。 Unionの作成者もUnionUserに登録するとはどのようにすれば良いのでしょうか? winterboumさんが言ったようにDBに何回もアクセスしていることはわかりました。確かにDBへのアクセスが少ない方がいいと思います。 自分がUnionを作成した際に@current_user.idがUnion のuser_idに保存されます。 中間テーブルであるUnionUserでは「Unionに参加する」ボタンをクリックするとクリックした時の@current_user.idがUnionUserのuser_idに保存されるようになっています。 作成者もUnionUserに登録するというメリットはわかったのですが作成した時にUnionUserにowner_id?のような者を作るやり方がわからないです
winterboum

2020/08/03 04:00

@current_user.idをUnion のuser_idにしまった時に、「「Unionに参加する」ボタンをクリック」した時に行う処理をしておけばよいです。
atage517

2020/08/03 06:47

ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問