0

我的产品模型在下面有这个验证规则,在测试规则时,我发现 uniqueness: true for :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     |

我不明白为什么唯一性根本不起作用?

4

1 回答 1

0
  1. 将代码添加到项目中的任何文件后,尝试重新启动服务器或重新加载控制台。

  2. 唯一性验证在 100% 事件中不受信任。要确保某些字段是唯一的,请在数据库中添加唯一索引。这是由于 uniq 验证在保存之前检查属性的值是唯一的,因此如果两个不同的数据库连接创建两个具有相同值的记录,它不会引发错误。

于 2018-02-20T12:57:14.257 回答