Se está encontrando con un problema de mayúsculas y minúsculas:sus nombres están en mayúsculas, pero los correos electrónicos están en minúsculas y, en la mayoría de las intercalaciones, las letras mayúsculas van antes que las minúsculas. Mira este ejemplo trivial:
#= select * from (values ('b'), ('B'), ('a'), ('A')) t (letter);
letter
--------
b
B
a
A
#= select * from (values ('b'), ('B'), ('a'), ('A')) t (letter) order by letter;
letter
--------
A
B
a
b
Entonces, su consulta funciona perfectamente, es solo que example@sqldat.com ordena después de Josh . Para evitar esto, puede ordenar por el valor en minúsculas. Esta es una versión simple de los datos que tiene:
#= select * from volunteers;
first_name | last_name | email
------------+-----------+--------------------
Josh | Broger | example@sqldat.com
Josh | Kenton | example@sqldat.com
∅ | ∅ | example@sqldat.com
Josh | Broger | example@sqldat.com
Alex | Diego | example@sqldat.com
Luego, para ordenar usando coalesce buscas:
#= select * from volunteers order by lower(coalesce(first_name, email));
first_name | last_name | email
------------+-----------+--------------------
Alex | Diego | example@sqldat.com
∅ | ∅ | example@sqldat.com
Josh | Broger | example@sqldat.com
Josh | Broger | example@sqldat.com
Josh | Kenton | example@sqldat.com
O para su versión completa usando ActiveRecord :
Volunteer
.joins(:volunteer_lists)
.where(
"(volunteer_lists.organizer_id = ? AND organizer_type = 'Organization') OR (volunteer_lists.organizer_id IN (?) AND organizer_type = 'Collaborative')",
organization.id, collaboratives
)
.order('LOWER(COALESCE("volunteers"."first_name", "volunteers"."last_name", "volunteers"."email"))')