下記のような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
作成時間(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 %>
①最終的にはjsonで出力したいと考えています。
②その通りです。
@user_groups = UserGroup.where(user_id:user.id)
render json: @user_groups
で可能でないでしょうか?
参考サイト
https://mebee.info/2020/09/28/post-14939/
そこでgroupのidを取得して、そのidからgroupの情報を取得しに行くという流れでしょうか??
最終的にjsonで出力したいのはuserが属しているgroupの作成日時(created_at)ですか?
最終的にjsonで出力したいのはuserが属している全てのgroupのnameとcreated_atです
こんな感じでしょうか?
ユーザーが属している中間テーブルを検索
@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
回答1件
あなたの回答
tips
プレビュー