这是我第一次尝试回答我自己的问题,因为有人可能会碰到这个问题,所以它可能会有所帮助.使用Firebird,我想使用UNION ALL组合两个查询的结果,然后在给定列上对结果输出进行排序.就像是:
(select C1, C2, C3 from T1) union all (select C1, C2, C3 from T2) order by C3
括号来自其他数据库的有效语法,并且需要确保UNION ALL的参数(定义为对表有效的操作 - 即无序的记录集)不会尝试单独排序.但是我无法在Firebird中使用此语法 - 如何才能完成?
SELECT C1, C2, C3 FROM ( select C1, C2, C3 from T1 union all select C1, C2, C3 from T2 ) order by C3
字段名称不必相等.这就是为什么你不能在订单中使用字段名称的原因.
您可以改用字段索引.如:
(select C1, C2, C3 from T1) union all (select C7, C8, C9 from T2) order by 3
怎么样:
select C1, C2, C3 from T1 union all select C1, C2, C3 from T2 order by 2
至少在较新的Firebird版本中,如果您按"数字"而不是使用别名进行排序,则它可以工作.