Как раз так, что абстракция Rails от необработанного SQL приводит меня в замешательство. В MySQL я мог бы сделать это:
UPDATE FROM tasks AS t
LEFT JOIN projects as p
ON t.project_id = p.id
SET t.invoice_id = 7
WHERE p.organization_id == 42
AND t.invoice_id IS NULL
Как я могу сделать это в Rails 3.0.1 с нетерпением загрузки? Я пробовал все следующее:
Tasks.joins(:project).where('projects.organization_id' => 42, :invoice_id => nil).update_all( :invoice_id => 7 )
И все варианты вышеизложенного. Все либо давали ошибки, либо ничего не нашли.
Затем я попытался использовать scope
:
Task.scope :find => {:joins => :project, :conditions => ["projects.organization_id == ? AND invoice_id IS NULL", @organization.id] } do
Task.update_all :invoice_id => @invoice.id
end
Это дало мне ошибку undefined method 'to_sym' for #<Hash:0x1065c6438>
.
Я потратил слишком много часов на это, просто чтобы воспроизвести простой SQL-запрос. Пожалуйста, помогите!
РЕДАКТИРОВАТЬ: Временное плохое решение, чтобы обойти n + 1:
task_ids = Task.select('tasks.id').joins(:project).where('projects.organization_id' => @organization.id, :invoice_id => nil).collect{|t| t.id}
Task.update_all ['invoice_id = ?', @invoice.id], ["id in (#{task_ids.join(',')})"]