【发布时间】:2010-09-28 20:56:39
【问题描述】:
我有一个具有两个不同操作的控制器,但都需要相同的代码,这有点长,我怎样才能让他们访问相同的行为但保持干燥?
@list = Contact.find :all,
:select => "companies.name AS co_name,
companies.id AS comp_id,
COUNT(contact_emails.id) AS email_count,
COUNT(contact_calls.id) AS call_count,
COUNT(contact_letters.id) AS letter_count,
COUNT(contact_postalcards.id) AS postalcard_count",
:conditions => ['contact_emails.date_sent < ? and contact_emails.date_sent > ?',
report_end_date, report_start_date],
:joins => [
"LEFT JOIN companies ON companies.id = contacts.company_id",
"LEFT JOIN contact_emails ON contact_emails.contact_id = contacts.id",
"LEFT JOIN contact_letters ON contact_letters.contact_id = contacts.id",
"LEFT JOIN contact_postalcards ON contact_postalcards.contact_id = contacts.id",
"LEFT JOIN contact_calls ON contact_calls.contact_id = contacts.id"
],
#:group => "companies.id"
:group => "companies.name"
puts @list[0].attributes.inspect
【问题讨论】:
-
这不是在回答您的问题,但我 90% 确定所有这些“连接”都可以替换为“包含”。像这样::include => [:companies, :contact_emails, :contact_letters, :contact_postalcards, :contact_calls]。
标签: ruby-on-rails controller dry