Как добавить к этому утверждение WHERE: выбрать в рельсах? - PullRequest
0 голосов
/ 21 сентября 2010

У меня есть текущий оператор поиска с: select:

@list = Contact.find :all,
  :select => "companies.name AS co_name,  
              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,",
  :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"

Я хочу получить только те экземпляры, в которых contact_email, contact_letters и так далее имеют date_sent report_start_date.

Как мне это сделать?

1 Ответ

1 голос
/ 21 сентября 2010

Добавив conditions.Например:

:conditions => ['contact_emails.date_sent < ? and contact_emails.date_sent > ?', report_end_date, report_start_date]
...