我一直在努力寻找实现这一目标的方法,但我找不到任何尝试,所以我想我的做法可能是完全错误的。也就是说,如果我希望两个字段的组合是唯一的,我应该在迁移中做些什么? 请注意,我不希望它们成为索引,只是数据库字段。
例如,对于下面的迁移,我可以单独将unique: true
添加到字段,但组合?
class CreateSomething < ActiveRecord::Migration
def change
create_table :something do |t|
t.date :datestamp, :null => false
t.integer :some_number, :null => false
t.timestamps
end
end
end
答案 0 :(得分:13)
我不确定你的意思
请注意,我不希望它们成为索引,只是数据库字段。
索引是数据库存储的有关列的信息的额外部分。 更重要的是,索引正是您所需要的!
class CreateSomething < ActiveRecord::Migration
def change
create_table :something do |t|
t.date :datestamp, :null => false
t.integer :some_number, :null => false
t.timestamps
end
add_index :something, [:datestamp, :some_number], unique: true
end
end