草庐IT

RecordNotUnique

全部标签

sql - Rails:使用 Postgres 创建对象时重复 ActiveRecord::RecordNotUnique?

我正在使用Rails4应用程序,它需要创建大量对象以响应来自另一个系统的事件。当我调用create!时,主键列上出现非常频繁的ActiveRecord::RecordNotUnique错误(由PG::UniqueViolation引起)我的模型之一。我在SO上找到了其他答案,建议挽救异常并调用retry:beginTableName.create!(data:'here')rescueActiveRecord::RecordNotUnique=>eife.message.include?'_pkey'#Onlyretryprimarykeyviolationslog.warn"Retr

ruby-on-rails - 如何正确处理 Rails 中的 ActiveRecord::RecordNotUnique

我试图在我的Rails项目中使用唯一索引来强制执行唯一性。我发现了一些令人困惑的事情。就像在我的站点注册用户一样,您需要提供电子邮件地址和昵称,两者都必须是唯一的。我为电子邮件和昵称添加了唯一索引。当重复出现时,我拯救异常ActiveRecord::RecordNotUnique,现在问题来了,我怎么知道哪个字段导致异常?非常感谢您的帮助。 最佳答案 恕我直言,您还应该添加uniquenessvalidators到你的模型。这允许您使用Rails的验证和错误消息。#addtomodelvalidates:email,uniquene

sql - 拯救 ActiveRecord::RecordNotUnique 时的问题

我正在尝试构建一个表,该表将充当第三方服务的批量同步队列。下面的方法应该不言自明;但需要明确的是,它的目的是向delayed_syncs表中添加一个具有status::queued的新可更新对象(多态关系)。多态关系+status(updatable_id,updatable_type,status)存在唯一性约束应该会导致已在队列中且具有:queuedstatus的可更新对象在此处失败并落入救援block。我看到的问题是,每当find_by生成的SELECT被触发时,整个方法都会失败并显示:ActiveRecord::StatementInvalid错误。我发现的有关这方面的信息建议

ruby-on-rails - find_or_create ActiveRecord::RecordNotUnique 救援重试不起作用

使用ruby​​2.1.2和rails4.1.4。我对数据库中的电子邮件列有唯一约束。如果存在一个线程正在创建用户而另一个线程试图同时创建的竞争条件,则会引发记录不唯一的异常。我正在尝试通过重试来处理此异常,以便在重试时它将在find_or_create的SELECT期间找到客户。然而,它似乎并没有起作用。它用尽重试次数,然后重新引发异常。这是我最初做的:retries=10beginuser=User.find_or_create_by(:email=>email)rescueActiveRecord::RecordNotUniqueretryunless(retries-=1).z