我有一个Release
模型medium
和country
列(以及其他).不应该releases
有相同medium
/ country
组合的共享.
我如何将其写为rails验证?
您可以使用选项使用唯一性验证scope
.
此外,您应该向数据库添加唯一索引,以防止新记录在写入之前同时检查时传递验证:
class AddUniqueIndexToReleases < ActiveRecord::Migration def change add_index :releases, [:country, :medium], unique: true end end class Release < ActiveRecord::Base validates :country, uniqueness: { scope: :medium } end
以上所有答案都缺少如何验证模型中多个属性的唯一性.下面的代码旨在告诉如何在范围中使用多个属性.
validates :country, uniqueness: { scope: [:medium, :another_medium] }
它验证country
值为medium
和的所有行的唯一性another_medium
.
注意:不要忘记在上面的列上添加索引,这可以确保快速检索并为唯一记录添加数据库级别验证.
您可以将:scope
参数传递给验证器,如下所示:
validates_uniqueness_of :medium, scope: :country
有关更多示例,请参阅文档.