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. 更新:如果创建索引,那么唯一性验证将运行得很快. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |