ruby-on-rails – 如果记录不存在,则创建

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 如果记录不存在,则创建前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的轨道应用程序中有3个模型
class Contact < ActiveRecord::Base
  belongs_to :survey,counter_cache: :contact_count
  belongs_to :voter
  has_many :contact_attempts
end

class Survey < ActiveRecord::Base
  has_many :questions
  has_many :contacts
end

class Voter < ActiveRecord::Base
  has_many :contacts
end

联系人由voter_id和survey_id组成.我的应用程序的逻辑是,在任何给定的调查中,一个选民只能有一个联系人.

现在我使用以下代码强制执行这个逻辑.我查询联系人表以获取与给定的voter_id和survey_id匹配的记录.如果不存在,则创建它.否则它什么都不做.

if !Contact.exists?(:survey_id => survey,:voter_id => voter)
   c = Contact.new
   c.survey_id = survey
   c.voter_id = voter
   c.save
end

显然,这需要一个选择和一个插入查询来创建1个潜在的联系人.当我一次添加可能成千上万的联系人.

现在我正在使用Resque来允许这个在后台运行并远离ui线程.我可以做些什么来加速,并提高效率?

解决方法

您应该首先添加一个数据库索引,以在最低级别强制执行此条件:
add_index :contacts,[:voter_id,:survey_id],unique: true

那么您应该在ActiveRecord级别添加唯一性验证:

validates_uniqueness_of :voter_id,scope: [:survey_id]

如果指定的选民和调查对象存在联系人,contact.save将返回false.

更新:如果创建索引,那么唯一性验证将运行得很快.

原文链接:https://www.f2er.com/ruby/273721.html

猜你在找的Ruby相关文章