解决union查询order by 排序失效的问题

简介: 解决union查询order by 排序失效的问题

如果要对两个结果集进行合并,我们一般会使用union(去重)查询,SQL如下:

select t1.age,t1.name from table1 t1
union 
select t2.age,t2.name from table2 t2

此时,需要对结果集按年龄进行排序,SQL如果这样写:

select t1.age,t1.name from table1 t1
union
select t2.age,t2.name from table2 t2
order by age    

这样排序是有问题的,排序还是有问题,改造sql如下:

select t11.age,t11.name (select t1.age,t1.name from table1 t1 order by t1.age )t11
union
select t22.age,t22.name (select t2.age,t2.name from table2 t2 order by t2.age)t22

这样写应该是没问题的,但是这样会被优化器优化,所以要加limit限制,最终的SQL如下:

select t11.age,t11.name (select t1.age,t1.name from table1 t1 order by t1.age limit 99999)t11
union
select t22.age,t22.name (select t2.age,t2.name from table2 t2 order by t2.age  limit 9
目录
相关文章
|
4月前
|
SQL 数据挖掘 数据库
|
7月前
|
SQL
SQL语句两个字段或多个字段同时order by 排序
SQL语句两个字段或多个字段同时order by 排序
1122 0
|
7月前
|
SQL 数据库管理
sqlite语句order by两个字段同时排序处理
sqlite语句order by两个字段同时排序处理
73 0
|
7月前
|
SQL
[已解决]使用order by 排序后的是10 6 7 8 9 而不是 6 7 8 9 10?
[已解决]使用order by 排序后的是10 6 7 8 9 而不是 6 7 8 9 10?
111 0
|
SQL
ORDER BY:对查询结果进行排序
ORDER BY:对查询结果进行排序
111 0
|
SQL Oracle 关系型数据库
SQL学习之使用order by 按照指定顺序排序或自定义顺序排序
我们通常需要根据客户需求对于查询出来的结果给客户提供自定义的排序方式,那么我们通常sql需要实现方式都有哪些,参考更多资料总结如下(不完善的和错误望大家指出): 一、如果我们只是对于在某个程序中的应用是需要按照如下的方式排序,我们只需在SQL语句级别设置排序方式:
720 0
|
存储 关系型数据库 MySQL
Innodb:使用索引避免排序后DESC和ASC的区别
Innodb:使用索引避免排序后DESC和ASC的区别
125 0
Innodb:使用索引避免排序后DESC和ASC的区别
|
SQL 数据库
除了会排序,你对ORDER BY的用法可能一无所知!(一)
小伙伴们在进行SQL排序时,都能很自然的使用到ORDER BY。不管是默认ASC的升序,还是DESC降序,几乎都是信手拈来。 今天给大家分享一些你可能不知道的ORDER BY用法。
除了会排序,你对ORDER BY的用法可能一无所知!(一)
|
XML SQL 数据库
除了会排序,你对ORDER BY的用法可能一无所知!(二)
小伙伴们在进行SQL排序时,都能很自然的使用到ORDER BY。不管是默认ASC的升序,还是DESC降序,几乎都是信手拈来。 今天给大家分享一些你可能不知道的ORDER BY用法。
除了会排序,你对ORDER BY的用法可能一无所知!(二)
|
数据库
分页limit和排序order by
分页limit和排序order by