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

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

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

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

Q&A

解決済

1回答

702閲覧

railsで中間テーブルのcreated_atを取得したい

oeiqgfodgfhps

総合スコア35

Ruby on Rails

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

0グッド

0クリップ

投稿2021/12/15 15:01

下記のようなUserとGroupのモデルがあり、n対nの関係のため中間テーブルであるGroupUserというモデルを作りました。
userが属している全てのgroupとそのgroupに属した時間を取得したいのですが、
user.groups
とやると、group自体が登録されたcreated_atの値が返ってくるので、時間にずれが出てきてしまいます。
groupに属した時間を取得しようとすると、中間テーブルにアクセスする必要があり、そこで取得した時間をgroupのcreated_atに代入し、値を返すようにしています。
かなりまどろっこしいというか冗長な書き方だと思うので、何か他にいい案があればご指導お願いしたいです。

ruby

1 user_groups = UserGroup.where(user_id:user.id) 2 result = user_groups.map{ |user_group| 3 group = UserGroup.find(user_group.group_id) 4 group.created_at = user_group.created_at 5 group.updated_at = user_group.updated_at 6 next group 7 }

ruby

1class User < ApplicationRecord 2 has_many :group_users 3 has_many :groups, through: :group_users 4end 5 6class Group < ApplicationRecord 7 has_many :group_users 8 has_many :users, through: :group_users 9end 10 11class GroupUser < ApplicationRecord 12 belongs_to :user 13 belongs_to :group 14end

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

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

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

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

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

Ryo-EAST

2021/12/15 16:48

作成時間(created_at)は最終的に ①ビューに表示するということでしょうか? ②特定のユーザーが属している全ての情報を表示したいですか? 上記の通りであればコントローラでインスタンス作成して ビューで表示すれば可能でないでしょうか? ・コントローラ(最初に@以外、1行目と同じです) @user_groups = UserGroup.where(user_id:user.id) ・ビュー(html.erb) <% @group_users.each do |group_user| %> <td><%= group_user.group.id %></td> <td><%= group_user.created_at %></td> <% end %>
oeiqgfodgfhps

2021/12/15 16:52

①最終的にはjsonで出力したいと考えています。 ②その通りです。
oeiqgfodgfhps

2021/12/15 17:09

そこでgroupのidを取得して、そのidからgroupの情報を取得しに行くという流れでしょうか??
Ryo-EAST

2021/12/15 17:14 編集

最終的にjsonで出力したいのはuserが属しているgroupの作成日時(created_at)ですか?
oeiqgfodgfhps

2021/12/15 17:18

最終的にjsonで出力したいのはuserが属している全てのgroupのnameとcreated_atです
Ryo-EAST

2021/12/15 17:40 編集

こんな感じでしょうか? ユーザーが属している中間テーブルを検索 @user_groups = UserGroup.where(user_id:user.id) 中間テーブルからグループを検索 @groups=Group.where(id: @user_groups.pluck(:group_id)) jsonを返す render json: @groups.select(:name, :created_at) このサイトに特定のカラムをjsonで返すがあります https://ccbaxy.xyz/blog/2019/11/05/ruby10/#guan-lian-moderuwo-json-chu-li-join-bian
guest

回答1

0

ベストアンサー

かなりまどろっこしいというか冗長な書き方だと思うので

素直にuser.group_usersを取ればいいだけではないでしょうか?

投稿2021/12/15 22:11

maisumakun

総合スコア146018

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

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

maisumakun

2021/12/15 22:14

そして、元のコードのuser_groups.mapのループの意図がわかりません(findで、全く無関係なユーザーのUserGroupを取ってくることも考えられます)。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問