wrap the whole statement in another select
select col1, col2, col5, col6 from (
SELECT
col1, col2, col5, col6
FROM
table
WHERE
col2 = 'X'
UNION
SELECT
col3, col4, col5, col6
FROM
table
WHERE
col4 = 'X'
) as t
order by coalesce(col1, col3);
John Sidney-Woollett
Chris Green wrote:
It's not quite clear (to me at least) whether I can have a UNION and
an ORDER BY in a SELECT statement.
What I want to do is:-
SELECT
col1, col2, col5, col6
FROM
table
WHERE
col2 = 'X'
UNION
SELECT
col3, col4, col5, col6
FROM
table
WHERE
col4 = 'X'
ORDER BY
coalesce(col1, col3)
Is this valid syntax allowed by postgresql? (I'm not at the system
where postgresql is installed at the moment so I can't just try it)
col1 and col3 are both DATE columns. col2 and col4 are both
varchar(1).
I want the ORDER BY to order the result of the UNION.
---------------------------(end of broadcast)---------------------------
TIP 4: Don't 'kill -9' the postmaster