我的产品型号下面有这个验证规则,在测试规则时,我发现唯一性:true:title实际上什么也没做。
validates( :title, presence: {message: ' must be given'}, uniqueness: true )
例如,如果我创建两个具有相同标题的实例,那么
a = Product.new title: 'title', description: 'hello!!', user: User.find(39)
a.save
id | title | description | price | created_at | updated_at | user_id |
+-----+-------+-------------+-------+--------------------+-------------+
162 | title | hello!! | 0.0 | 2018-... | 2018-02... | 39 |
b = Product.new title: 'title', description: 'hahah', user: User.find(39)
b.save
id | title | description | price | created_at | updated_at | user_id |
+-----+-------+-------------+-------+--------------------+-------------+
163 | title | hahah | 0.0 | 2018-... | 2018-02-2... | 39 |
我不明白为什么唯一性根本不起作用?
答案 0 :(得分:0)
在将代码添加到项目中的任何文件后,尝试重新启动服务器或重新加载控制台。
100%事件不信任唯一性验证。要确保某些字段是唯一的,请在数据库中添加唯一索引。 由uniq验证引起的属性值在保存之前是唯一的,因此如果两个不同的数据库连接创建两个具有相同值的记录,则不会引发错误。