迁移中范围的唯一性 [英] Uniqueness with scope in migration

查看:17
本文介绍了迁移中范围的唯一性的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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

例如,对于下面的迁移,我可以将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

推荐答案

我不确定您说的

是什么意思

请注意,我不希望它们是索引,只希望它们是数据库字段。

索引是数据库存储的有关列的信息的额外部分。 更重要的是,索引正是您所需要的!

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

这篇关于迁移中范围的唯一性的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆