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版本中,如果您按"数字"而不是使用别名进行排序,则它可以工作.
归档时间: |
|
查看次数: |
39548 次 |
最近记录: |