Мне нужно сделать сложное внешнее соединение. Я хочу получить строку в результате для service interval
, если к нему не подключен service_note
. Как видно из запроса, service_interval
принадлежит одному service_job
, который связан с service_notes через объединенную таблицу service_note_jobs
. В настоящий момент он возвращает пустое отношение, если к этому service_interval
не подключено service_note
.
def self.distance_and_time_until_next_service(service_interval_ids)
ServiceInterval
.left_joins(vehicle: { service_notes: :service_note_jobs })
.where(
'service_note_jobs.service_job_id = service_intervals.service_job_id AND '\
'service_intervals.vehicle_id = service_notes.vehicle_id'
)
.where(service_intervals: { id: service_interval_ids })
.group('service_intervals.id')
.select(
'service_intervals.id',
"MAX(GREATEST(service_notes.odometer, service_intervals.created_odometer) - vehicles.odometer + service_intervals.distance_interval) AS distance_left_until_next_service",
"MAX(ROUND(EXTRACT(epoch FROM(GREATEST(service_notes.date, service_intervals.created_at) - NOW())) / 86400 + service_intervals.time_interval)) AS time_left_until_next_service"
)
end