Postgres przestrzega standardu, zezwalając na aliasy kolumn jako order by
Klucze. Więc to działa:
SELECT CONCAT(first_name, last_name) AS full_name
FROM customer
ORDER BY full_name;
Nie obejmuje to jednak wyrażeń za pomocą aliasów. Możesz to naprawić za pomocą podzapytań lub CTE. Mogę również zasugerować sprzężenie boczne:
SELECT v.full_name
FROM customer c CROSS JOIN LATERAL
(VALUES (CONCAT(c.first_name, c.last_name))) v(full_name)
ORDER BY v.full_name;