迁移时是否需要对belongs_to/has_many关系使用add_index?(Rails 3.2,Active Record)

Mat*_*ieu 7 ruby activerecord ruby-on-rails ruby-on-rails-3

我的问题很简单,但我找不到明确的答案.

我建立了每日优惠Rails应用程序.

  • 每笔交易都有很多产品(has_many)

  • 每个产品都属于一笔交易

Rails指南中获取 2.3 ,我将在迁移中使用它:

   class CreateDeal < ActiveRecord::Migration
    def change
      create_table :deals do |t|
        t.string :name
        t.timestamps
      end

      create_table :products do |t|
        t.belongs_to :Deal
        t.timestamps
      end
    end
   end
Run Code Online (Sandbox Code Playgroud)

自动,Rails /活动记录会在产品表中添加一列Transactions_id对吗?

我是否需要通过添加到我的迁移手动(如下所示)在此deals_id列上添加索引,add_index还是"自动"完成,因为我设置了belongs_to/has_many关系?

create_table :products do |t|
  t.belongs_to :Deal
  t.timestamps

  add_index :products, :deals_id 
end
Run Code Online (Sandbox Code Playgroud)

Hel*_*rra 13

您确实需要自己添加索引...但是,如果您对模型使用命令行生成器并使用belongs_to,则Rails会将索引添加到迁移中...

例如

rails g model product deal:belongs_to
Run Code Online (Sandbox Code Playgroud)

会产生

class CreateProducts < ActiveRecord::Migration
  def change
    create table :products do |t|
      t.belongs_to :deal

      t.timestamps
    end
    add_index :products, :deal_id
  end
end
Run Code Online (Sandbox Code Playgroud)