我的Event
模型与many-to-many
模型有Service
关联
用户可以创建一个事件,并选择标记该事件的服务。
用户可以订阅服务,当创建事件时,如果用户订阅了在该事件中标记的服务,则应通知用户。
此外,User
模型与has_many
模型有Email
关联。
我希望能够获得所有电子邮件地址的数组,以便我可以向订阅者发送通知。
这就是我所拥有的:
class Event < ActiveRecord::Base
has_many :event_services, :dependent => :destroy
has_many :services, :through => :event_services
def recipients
recipients = services.each_with_object(arr = []) do |service|
service.users.each do |user|
user.emails.each do |email|
arr << email.address
end
end
end
end
recipients.uniq
end
这很有效,但它的超级丑陋且效率不高。我该如何优化这个?
这是我的电子邮件模型:
class Email < ActiveRecord::Base
attr_accessible :address, :user_id
belongs_to :user
end
答案 0 :(得分:3)
使用单个SQL请求会更有效使用multiple joins的以下请求应该有效:
def recipients
Email.joins(:user => {:services => :event_services}).where(:event_services => {:event_id => self.id}).pluck(:address).uniq
end