我正在开发一个Ruby on Rails Web应用程序。我想一起验证多个字段的唯一性。我怎么能这样做?
例如:我有一个名为waiting
的模型,其中包含三个字段:
project_id
category_id
和user_id
我想确保在所有三个字段中不会有两个相同的行。
答案 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
当然,您可以在数据库模式中使用唯一键,然后在极少数情况下捕获相关的例外。