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

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

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

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

Q&A

解決済

2回答

1974閲覧

Railsでのデータベース設計について

Leoneo

総合スコア11

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2015/07/06 06:36

現在Rails歴は約二ヶ月でブログ兼SNSのようなものを作っております。

記事を投稿するのは私のみで、各ユーザーは一つの記事に対して一つだけコメントができるような形になっていますが、そのデータベースの設計の仕方がよくわかりません。

User1 User2 User3
Post1-Comment Post1-Comment Post2-Comment
Post2-Comment Post3-Comment
Post3-Comment

のように各ユーザーごとに複数のpost(記事)とそれにひも付けられたcomment(コメント)を持つような形です。

lang

1class User has_many :posts 2class Post belongs_to :users, has_many :comments 3class Comment belongs_to :posts

と試していますが、これだとユーザーとコメントがきちんと関連性を持っているとは思えません。

どのようにデータベースを設計したらよいのでしょうか。
データベースはつい最近勉強し始めたばかりです。

うまく伝えられているのかはわかりませんが、みなさんの助けをお借りしたいです。
説明が足りていないわかりにくい箇所があれば随時修正加筆いたします。
ぜひよろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

次のような comment と user の関係を記載してあげる必要があると思います。

1 m 1 m m 1 user ---> post ---> comment <--- user
class User < ActiveRecord::Base has_many :posts, has_many :comments end class Post < ActiveRecord::Base belongs_to :user, has_many :comments class Comment < ActiveRecord::Base belongs_to :post, belongs_to :user end

投稿2015/07/06 14:23

katoy

総合スコア22324

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

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

Leoneo

2015/07/07 07:17

回答ありがとうございました! 他にも理解しなければいけないことがあってすぐには試せていないのですが、トライしてみます!
guest

0

記事を書けるユーザーと、コメントしかできないユーザーを分離してあげなくてはいけないのでは?

lang

1class User 2 has_one: post_user 3 has_one: comment_user 4end 5class PostUser 6 has_many :posts 7 belongs_to :user 8end 9class CommentUser 10 has_many :comments 11 belongs_to :user 12end 13class Post 14 belongs_to :post_user 15 has_many :comments 16end 17class Comment 18 belongs_to :post 19 belongs_to :comment_user 20end

こんな感じ。

投稿2015/07/06 06:49

rifuch

総合スコア1901

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

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

Leoneo

2015/07/07 07:18

回答ありがとうございました! 記事を書けるのはWriterという別のmodelを用意しています。 うまく置き換えてトライしてみます!
rifuch

2015/07/07 07:28 編集

なるほど、そういうことですね。 であれば、Userの権限識別用のレコードは必要ありませんね。 class Writer has_many :posts end class User has_many :comments end class Post belongs_to :writer has_many :comments end class Comment belongs_to :post belongs_to :user end ってかんじですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問