使用index:true命名迁移中的索引

时间:2014-10-16 17:26:43

标签: ruby-on-rails ruby indexing naming

我有一个迁移,在下面,我用index:true创建索引。但是,该索引的名称太长,所以我试图自己命名。但是,这似乎没有运行。我得到相同的“名字太长”错误。有没有办法用index:true命名这样的索引?如果没有,我该如何用add_index命名呢?

class CreateVehicleProductApplicationNotes < ActiveRecord::Migration
  def change
    create_table :vehicle_product_application_notes do |t|
      t.references :product_id, index: true
      t.references :product_application_id, index: true, :name "my_index"
      t.references :note_id, index: true

      t.timestamps
    end
  end
end

1 个答案:

答案 0 :(得分:9)

而不是true,您可以传递包含索引名称的Hash,如下所示,

t.references :product_application_id, index: { name: "my_index" }

参考: http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/TableDefinition.html