在Firebird中组合UNION ALL和ORDER BY

Chr*_*ris 14 sql database firebird database-design

这是我第一次尝试回答我自己的问题,因为有人可能会碰到这个问题,所以它可能会有所帮助.使用Firebird,我想使用UNION ALL组合两个查询的结果,然后在给定列上对结果输出进行排序.就像是:

(select C1, C2, C3 from T1)
union all 
(select C1, C2, C3 from T2)
order by C3
Run Code Online (Sandbox Code Playgroud)

括号来自其他数据库的有效语法,并且需要确保UNION ALL的参数(定义为对表有效的操作 - 即无序的记录集)不会尝试单独排序.但是我无法在Firebird中使用此语法 - 如何才能完成?

Cad*_*oux 27

SELECT C1, C2, C3
FROM (
    select C1, C2, C3 from T1
    union all 
    select C1, C2, C3 from T2
)
order by C3
Run Code Online (Sandbox Code Playgroud)


Dou*_*osi 12

字段名称不必相等.这就是为什么你不能在订单中使用字段名称的原因.
您可以改用字段索引.如:

(select C1, C2, C3 from T1)
union all 
(select C7, C8, C9 from T2)
order by 3  
Run Code Online (Sandbox Code Playgroud)


小智 6

怎么样:

select C1, C2, C3 from T1
union all 
select C1, C2, C3 from T2
order by 2
Run Code Online (Sandbox Code Playgroud)

至少在较新的Firebird版本中,如果您按"数字"而不是使用别名进行排序,则它可以工作.