独特的三个不同领域

时间:2011-01-23 15:45:58

标签: ruby-on-rails-3 unique

我正在开发一个Ruby on Rails Web应用程序。我想一起验证多个字段的唯一性。我怎么能这样做?

例如:我有一个名为waiting的模型,其中包含三个字段:

project_id category_iduser_id

我想确保在所有三个字段中不会有两个相同的行。

2 个答案:

答案 0 :(得分:2)

为什么不只是:

validates_uniqueness_of :user_id, :scope => [:project_id, :category_id]

+

add_index :waitings, [:project_id, :category_id, :user_id], :unique => true

阅读API:

答案 1 :(得分:-1)

它不漂亮,但这对我有用:

class Waiting < ActiveRecord::Base
  validate :must_be_unique

  def must_be_unique
    if self.class.where(project_id: project_id, category_id: category_id, user_id: user_id).exists?
      errors.add(:base, 'Must be unique')
    end
  end
end

当然,您可以在数据库模式中使用唯一键,然后在极少数情况下捕获相关的例外。