SELECT *
FROM table1 t1
LEFT JOIN
table2
ON o.id =
(
SELECT o_id
FROM table2 t2
WHERE t2.c_id = t1.c_id
ORDER BY
t2.c_id DESC, t2.isHeadOffice DESC, t2.o_id DESC
LIMIT 1
)
Skapa ett index på table2 (c_id, isHeadOffice, o_id)
för att detta ska fungera snabbt.
ORDER BY
klausulen i underfrågan kan verka överflödig men den krävs för MySQL
för att välja rätt index.