加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 20:35:26 所属栏目:百科 来源:网络整理
导读:我的轨道应用程序中有3个模型 class Contact ActiveRecord::Base belongs_to :survey,counter_cache: :contact_count belongs_to :voter has_many :contact_attemptsendclass Survey ActiveRecord::Base has_many :questions has_many :contactsendclass Vot
我的轨道应用程序中有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.

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读