プログラミングマガジン

プログラミングを中心にIT技術をできるだけわかりやすくまとめます。

  • ホーム
  • Ruby on Rails
  • 【Ruby on Rails】モデル同士を関連づけを便利に扱う機能
 
 
     
  • サーバー言語  
    • Python
    • Ruby
    • PHP
    • SQL
  •  
  • インフラ  
       
    • AWS
    •  
    • 基本
    • Git
  • Web
       
    • Web開発
    • JavaScript
    • Vue.js
    • React
  •  
  • 設計  
       
    • 実装設計
    • DB設計
  • 問い合わせ
  

【Ruby on Rails】モデル同士を関連づけを便利に扱う機能

11.30

  • miyabisan2
  • コメントを書く

この記事は2分で読めます

ここでご紹介するのはあくまでRailsでモデル同士の関連づけがあった場合に便利に扱う機能のご紹介であり絶対に関連づけがある際に定義しなければ動かないというわけではありませんが知っておくと非常に開発効率が上がる機能なので知識として知っておきましょう。

1:1の場合

1
has_one:

多:1になる場合

それぞれのモデルファイル(app/models/モデル名.rb)に対して下記の記述をします。

多の方のモデルファイル

1
belongs_to:1の方のモデル名

belongs_toは外部キーとして抱えているただ一人だけ存在する親モデルを指定するイメージです。

1の方のモデルファイル

1
has_many :多の方のモデル名

has_manyは外部キーとしてリンクしている他のモデルが複数登録が可能であることを示しています。たくさん抱える子供を指定するイメージです。なおここに記述するモデル名はモデル名を複数形にする必要があります。

親(1の方のモデル)が削除されたら紐づく子(多の方のモデル)を削除する。

親が削除されたら子も削除する記述方法はこちらになります。delete_allに比べたら1件1件削除するのでパフォーマンスは悪いですが、関連づけのさらに関連づけまで削除できたりするので使い分けが必要になります。

1
dependent: :destroy

関連づけをまとめて削除ができるのでdestroyに比べるとパフォーマンスが良いです。

1
dependent: :delete_all

また、これらのdependentメソッドが機能するのはdestroyメソッドでの削除の場合だけになるのでその点も注意しましょう。(deleteメソッドでは機能しません。)

実際にプログラム内で使うには?

上記のような指定をすることで下記の指定をすることで親モデルに紐づく子モデルを全て取得することが可能になります。

1
親モデル(1).子モデル(多)

例えば、一意に決まるUserモデルに紐づく、Workモデルがあったとしたらuser.worksと行ったメソッドで全てのUserモデルに紐づくWorkを取得することが可能になります。

多:多の場合

中間テーブルを作成する方法

最も一般的な方法になります。テーブル間の紐付けを管理する中間テーブルを作成します。中間テーブルと1の方のテーブルに「has_many」を設定する必要があります。中間テーブルのhas_manyに「:through」を設定する必要があります。柔軟な反面、自分で行う作業が増えるので大変です。

has_and_belongs_to_manyを使う方法

単純で簡潔に記述ができる。

annnotate(便利なGem)

テーブルの構造を確認したいときにわざわざDBに接続しなくてもモデルファイルを見れば理解できるようになり非常に便利です。

1
2
3
4
5
6
7
8
9
10
group :development do
  # Access an IRB console on exception pages or by using <%= console %> anywhere in the code.
  gem 'web-console'
  gem 'listen', '~> 3.0.5'
  # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
  gem 'spring'
  gem 'spring-watcher-listen', '~> 2.0.0'
  gem 'pry-byebug'
  gem 'annotate' ★追加
end

既存のファイルにアノテーションが追加されるように下記コマンドを実行する。

1
annotation

Dockerを使っている場合

1
docker-compose exec web bundle exec annotate

これでモデルファイルにDB構造が追記されます。

モデルファイルにDB構造が追記されない場合

下記でannotateの設定ファイルをインストールする。

1
rails g annotate:install

作成された「 lib/tasks/auto_annotate_models.rake 」を開き下記の記述をtrue → falseに変更する。

1
'show_indexes'              => 'true',

再度「annotation」コマンドを実行します。

テーブルをマイグレーションで作成するたびにDB構造が追記させる方法

下記コマンドを実行するだけで良いです。

1
rails g annotate:install

スポンサーリンク
  • 2019 11.30
  • miyabisan2
  • コメントを書く
  • Ruby on Rails
  • Tweets Twitter
  • このエントリーをはてなブックマークに追加
  • LINEで送る

関連記事

  1. 2021 01.30

    【Ruby on Rails】「Enumrize」について

  2. 2020 01.10

    【Ruby on Rails】「cancancan」について

  3. 2019 12.08

    【Ruby on Rails】「Turbolinks」によるページ遷移高速化

  4. 2019 12.24

    【Ruby on Rails】「rake」について

  5. 2020 11.16

    【Ruby on Rails】「cocoon」について

  6. 2019 12.07

    【Ruby on Rails】「ページング」の実装(kaminari)

  • コメント ( 0 )
  • トラックバック ( 0 )
  1. この記事へのコメントはありません。

  1. この記事へのトラックバックはありません。

返信をキャンセルする。

【Ruby on Rails】モデルの状態を自動制御す…

【Ruby on Rails】モデルのデータを絞り込む…

RETURN TOP

著者プロフィール

エンジニア歴10年で過去に業務系、Webデザイン、インフラ系なども経験あります。現在はWeb系でフロントエンド開発中心です。

詳細なプロフィールはこちら

スポンサーリンク

カテゴリー

  • Android
  • AngularJS
  • API
  • AWS
  • C++
  • CSS
  • C言語
  • DDD
  • DevOps
  • Django
  • Docker
  • Figma
  • Git
  • GitLab
  • GraphQL
  • gRPC
  • Hasura
  • Java
  • JavaScript
  • Kubernetes
  • Laravel
  • linux
  • MySQL
  • Next.js
  • nginx
  • Node.js
  • NoSQL
  • Nuxt.js
  • Oracle
  • PHP
  • Python
  • React
  • Redux
  • Rspec
  • Ruby
  • Ruby on Rails
  • Sass
  • Spring Framework
  • SQL
  • TypeScript
  • Unity
  • Vue.js
  • Webサービス開発
  • Webデザイン
  • Web技術
  • インフラ
  • オブジェクト指向
  • システム開発
  • セキュリティ
  • その他
  • データベース
  • デザインパターン
  • テスト
  • ネットワーク
  • プログラミング全般
  • マイクロサービス
  • マイクロソフト系技術
  • マルチメディア
  • リファクタリング
  • 副業
  • 未分類
  • 業務知識
  • 生成AI
  • 設計
  • 関数型言語
RETURN TOP

Copyright ©  プログラミングマガジン | プライバシーポリシー