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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

1003閲覧

railsチュートリアルについて

tanakazu2412

総合スコア12

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2019/10/06 17:49

編集2019/10/06 17:52

railsチュートリアルについて疑問に思ったのですが、
フォロー機能を実装する過程で、RelationShipモデルを作成する際に、
DB側のRelationShipsテーブルにキーを追加するのですが、
「follower_id」と「followed_id」の2つを条件としたキーを追加したのはなぜなのでしょうか?

該当部分

ruby

1class CreateRelationships < ActiveRecord::Migration[5.2] 2 def change 3 create_table :relationships do |t| 4 t.integer :follower_id 5 t.integer :followed_id 6 7 t.timestamps 8 end 9 add_index :relationships, :follower_id 10 add_index :relationships, :followed_id 11 # ここ 12 add_index :relationships, [:follower_id, :followed_id], unique: true 13 end 14end 15

見ている限りだと、まず「follower_id」と「followed_id」どちらかでviewのようなものを作って
そこからもう片方のカラムで条件していしているように見えます。

初歩的な質問で申し訳ないのですがよろしくおねがいします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

add_index :relationships, [:follower_id, :followed_id], unique: true

この部分でしょうか?

この部分は:relationshipsテーブル内の :follower_id,:followed_idカラムの組み合わせ
が常に一意性を持つように強制する記述(unique: true)をしています。
そうしないと同じユーザーを何回もフォローすることができるようになってしまう、という理由だったはずです。

ここでなかったらすみません、、、

投稿2019/10/06 18:23

編集2019/10/06 18:25
arinc0

総合スコア31

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

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

tanakazu2412

2019/10/06 18:29

indexを追加したのは、抽出処理の短縮ではなく、複合ユニーク設定が目的だったのですね。 indexの役割について理解不足でした。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問