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

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

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

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

Q&A

1回答

460閲覧

親子関係のある3つのテーブルを結合してデータを取得したい

Khy

総合スコア118

Ruby on Rails

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

0グッド

0クリップ

投稿2020/01/21 16:17

編集2022/01/12 10:55

Rails APIで以下の3つのテーブルを結合してデータを取得する方法がわからないためご質問させて頂きます。

【Departmentsテーブル】has_many :users
name

【Usersテーブル】has_many :posts, belongs_to :department
name
department_id

【Postsテーブル】belongs_to :user
title
user_id

上記のようなテーブルを結合させて、フロント側では以下のようなフォーマットで取得したいと考えております。

{ title: '営業部山田の記事', user: { name: '山田', department: { name: '営業部' } } }

現状のpost_controller.rbは次のようになっておりapi/v1/posts/:posts_id/usersにアクセスしたらUsersテーブルとPostsテーブルを結合した結果が取得できています。
これにUsersテーブルが参照しているDepartmentsテーブルのnameの値も合わせたい場合、何かいい方法はございますでしょうか?

Postsテーブルにdepartments_idを加えてデータを取得する方法も考えましたが、システムの設計上上記のような形でデータを取得したいと思っております。

rb

1# post_controller.rb 2module Api 3 module V1 4 class PostsController < ApiController 5 6 def index 7 posts = Post.where(user_id: params[:user_id]) 8 render json: { data: posts.as_json(:include => [:user])} 9 end 10 end 11end

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

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

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

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

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

guest

回答1

0

posts = Royalty.includes(user: :department).where(user_id: params[:user_id]) render json: { data: posts.as_json(:include => [user: :department])}

で試してください
as_jsonは経験ないのですが、、、、

投稿2020/01/22 00:24

winterboum

総合スコア23284

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問