我有一个迁移,在下面,我用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
答案 0 :(得分:9)
而不是true,您可以传递包含索引名称的Hash,如下所示,
t.references :product_application_id, index: { name: "my_index" }
参考: http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/TableDefinition.html