64
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

DMM WEBCAMPAdvent Calendar 2023

Day 10

【Rails】初心者様向けアソシエーション解説 book.user編

Last updated at Posted at 2023-12-09

はじめに

こんにちは!
DMM WEBCAMP mentor Advent Calendar 2023 :christmas_tree: 10日目 を担当します
@A22Dです!
初めての記事執筆となりますが、今回、Railsの「アソシエーション」に焦点を当て、その基本をわかりやすく説明したいと思います。
初心者の方でも「なるほど!」と思っていただけるよう心掛けますので、最後までお付き合いください!

概要

初心者の方へ、Railsの「アソシエーション」をわかりやすく解説します。
アソシエーションとは、モデル間の関連性を定義する強力な機能です。この記事では、例としてbook.user.namebook.user.introductionを用いて、投稿された本の作者の名前やプロフィール画像の取得方法を紹介します。

前提環境

  • Ruby 3.1.2
  • Rails 6.1.7

目次

  1. 1:Nの関係について
  2. book.userについて
  3. アソシエーションのイメージ: 子供とお母さんの関係
  4. book.user.nameの解析
  5. まとめ
  6. おまけ
  7. おわりに

1:Nの関係について

初学者向けに1:Nの関係を理解しやすくするため、この記事では「親」と「子」という表現を使って説明します。

user.rbのアソシエーション

has_many :books, dependent: :destroy
  • こちらはUserモデル(親)がたくさんのBookモデル(子)を持っているという関係性を示しています。
  • dependent: :destroyは本を投稿したユーザーが消えた時、消えたユーザーが投稿した本もまとめて消すよー!っていうようなオプションです。
dependent: :destroy について

dependent: :destroyはRailsのアソシエーションにおけるオプションの一つです。これを設定することで、あるモデル(例: Userモデル)が削除されたとき、関連付けられているモデルのデータ(例: Userが持っているBook)も一緒に削除されるようになります。

例えば、user.rbに以下のような関連付けがある場合、

has_many :books, dependent: :destroy

このUserが削除されると、そのUserに関連付けられている全てのBookも自動的に削除されます。これによりデータの整合性を保つことができます。

book.rbのアソシエーション

belongs_to :user
  • こちらはBookモデル(子)がUserモデル(親)に属しているという関係性を示しています。

book.userについて

今回はbook.user.nameを通じて、BookモデルからUserモデルのレコードを参照している理由について深く掘り下げます。

book.user.nameの日本語訳

初めに、book.user.nameを日本語に訳すと「本、人、名前」となります。このままでは意味が伝わりにくいですね。
しかし、もう少し考えて訳すと「本を投稿した人の名前」という意味になります。この表現ならば理解しやすいですね。

なぜこのような参照が可能か?

では、book.user.nameを使って、なぜ「本を投稿した人の名前」を参照できるのかを詳しく見ていきましょう。

  • 親子関係の識別: Bookモデル(子)は投稿者のIDを持っており、これを使ってUserモデル(親)を識別できます。

  • 外部キーの役割: この関係性は、子供が自分の親の情報を知っているようなものです。具体的には、user_idを外部キーとして持っているbookは、関連するuserの情報を参照できるのです。

外部キーが存在しないと、、
  • 外部キーが存在しないと、親の情報を持たない子供は、この子は一体誰の子供なのか、となってしまいますよね。そのため、子供は必ず外部キー(親の情報)を持っていなければならないということになります。

  • 外部キーが存在していない場合、必ず存在しなければならないという系統のエラー(〜must exist)が発生する可能性があります。

アソシエーションのイメージ: 子供とお母さんの関係

  • book.user.nameの動作は、子供がお母さんに名前を尋ねる概念に似ています。
  1. 子供(book)はお母さん(user)を知っています。
  2. 子供がお母さんの名前(name)を知りたい時、直接お母さんに尋ねます。
  3. お母さんはその答え(名前)を子供に教えます。

こんな形で親子関係を結んでいるから子供がお母さんの名前を知ることができるように本も投稿者の名前を知ることができます。(bookとuserがアソシエーションを結んでいることがポイント!)

book.user.nameではこのような動きを、アソシエーションを通じてコードで再現しているのです。

book.user.nameの解析

今回は以下のテーブルから桃太郎を投稿した人の名前をどのように拾ってくるのかを表を使って表します。

Bookテーブル

id title body user_id
1 桃太郎 桃太郎の物語です 1
2 浦島太郎 浦島太郎の物語です 1
3 一寸法師 一寸法師の物語です 2
4 かぐや姫 かぐや姫の物語です 3

Userテーブル

id name introduction
1 サトウ 読書が趣味です
2 ヤマダ 料理が趣味です
3 スズキ 運動が趣味です

book

まず、bookは「桃太郎」のレコードを参照しています。

id title body user_id
1 桃太郎 桃太郎の物語です 1

book.user

book.userは、簡単に言えば「この本を投稿したユーザーは誰?」と問いかけるコードです。

  • 例えば、ある本が「サトウ」というユーザーによって投稿された場合、book.userを使うことでその「サトウ」さんの情報にアクセスすることができます。
  • このbookに関連づけられたuser_idは1です。そのため、Userテーブルからidが1のレコードを参照します。
id name introduction
1 サトウ 読書が趣味です

book. user. name

そして、このユーザーレコードからnameカラムの値、つまり「サトウ」を取得します。

結論

book.user.nameを実行すると、「桃太郎」を投稿したユーザーの名前、すなわち「サトウ」という結果が得られます。

まとめ

Railsのアソシエーションは、モデル間の関係性を表現するキーです。親子関係のアナロジーを用いることで、book.user.nameのようなコードがどのように動作するかをイメージしやすくしました。簡単に言えば、子モデルが親モデルの情報を引き出すように、アソシエーションを使えば関連するモデルのデータにアクセスできます。この記事を通じて、アソシエーションの基本を理解していただければ幸いです。

おまけ

/book/3の詳細ページで@book.user.introductionには何が入るのか一緒に考えてみましょう。
URL /book/3 は、IDが3のBookモデルの詳細ページを示しています。

Bookテーブル

id title body user_id
1 桃太郎 桃太郎の物語です 1
2 浦島太郎 浦島太郎の物語です 1
3 一寸法師 一寸法師の物語です 2
4 かぐや姫 かぐや姫の物語です 3

Userテーブル

id name introduction
1 サトウ 読書が趣味です
2 ヤマダ 料理が趣味です
3 スズキ 運動が趣味です
答えと解説

コントローラの@bookの中身

@book = Book.find(params[:id])

このparams[:id]は3を意味します。そのため、IDが3のBookのレコードを@bookに代入します。

id title body user_id
3 一寸法師 一寸法師の物語です 2

Viewファイルでの@book.userの動作

@bookuser_idは2です。このuser_idをもとに関連するUserのレコードを取得します

id name introduction
2 ヤマダ 料理が趣味です

@book.user.introductionの動作

ヤマダさんのintroductionは「料理が趣味です」となります。

答え

結果として、@book.user.introductionは、「料理が趣味です」という内容を表示します。

おわりに

いかがでしたでしょうか。
今回の記事では、Railsのアソシエーション、特にモデル間の関連性を「親子関係」というアナロジーを用いて解説しました。book.user.nameのようなコードの背後にある仕組みを、より直感的に理解してもらうことを目指しました。🧐
初心者の方々がRailsのアソシエーションについて「なるほど!」と感じてもらえる内容としてまとめ上げましたが、まだまだ深掘りできる部分は多いです。今後の学習の中で、この記事が一つの足がかりとなれば幸いです。🎉
最後までお読みいただき、心から感謝いたします。🙇
明日からもAdvent Calendarはまだまだ続くので他の記事も読んで貰えると感無量です!!😭一緒に学んでいきましょう!!💪🔥🔥

64
13
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
64
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?