我的轨道应用程序中有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线程.我可以做些什么来加速,并提高效率?