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

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

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

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

Q&A

3回答

1714閲覧

1対多のリレーションで参照元の情報を取得するには

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby on Rails

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

0グッド

1クリップ

投稿2017/02/27 08:02

テーブルとして

  • User
  • Entry
  • Comment

があるとします。

User:Entry = 1:多
User:Comment = 1:多
Entry:Comment = 1:多

のような関係とします。

この場合、特定のUserのすべてのコメントから、Entryを取得する方法について迷っています。コメントしたすべてのEntryを取得するということです。

簡単に考えられる手法としては、

UserのすべてのCommentを得る
CommentからEntryを一つずつ取得
取得したEntryを重複を省いてまとめる

この方法以外に、良い手法はあるでしょうか?
またこれをRailsで実装しようとした場合よいメソッドはないでしょうか?

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

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

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

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

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

guest

回答3

0

TYPE A AS (
SELECT
entry.,Comment.
FROM
entry
INNER JOIN
Comment
ON (entry.結合Column = Comment.結合Column)
)
SELECT DISTINCT
User.,A.
FROM
User
INNER JOIN
A
ON (User.結合Column = A.結合Column)

投稿2017/03/03 16:05

AtsushiAsato

総合スコア12

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

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

0

以下のようにassociationの張り方で実装できそうです

ruby

1class User < ApplicationRecord 2 has_many :entries 3 has_many :comments 4 has_many :entry_comments, class_name: 'Comment', foreign_key: :entry_id 5end

投稿2017/03/03 10:28

編集2017/03/03 10:29
satoshih

総合スコア797

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

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

0

SQLite か、MySQLか、分かりませんが、一般的なSQLでCommentテーブルが持っているであろうフィールドを使って、

SQL

1select Comment.UserID, MIN(Comment.EntryID) 2from (Select * From User, Comment Where User.ID = Comment.UserID) 3group by Comment.EntryID 4order by Comment.EntryID

という形式のデータ抽出ができます。
これをもとに、in句やWhere句の中の副問い合わせを組み合わせてUserテーブルからユーザ名やEntryテーブルから日付などを引っ張ってくるように拡張することになるでしょう。

投稿2017/02/27 13:52

seastar3

総合スコア2285

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問