Ruby   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了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.

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

大佬总结

以上是大佬教程为你收集整理的ruby-on-rails – 如果记录不存在,则创建全部内容,希望文章能够帮你解决ruby-on-rails – 如果记录不存在,则创建所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。