迁移范围的唯一性

seb*_*kom 8 migration ruby-on-rails unique

我一直试图找到一种方法来实现这一点,但我找不到任何尝试,所以我在想,也许我的方法是完全错误的.也就是说,如果我希望两个字段的组合是唯一的,我应该在迁移中做些什么?请注意,我不希望它们是索引,只是数据库字段.

例如,对于下面的迁移,我可以单独添加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
Run Code Online (Sandbox Code Playgroud)

小智 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
Run Code Online (Sandbox Code Playgroud)