SQL用了Union后的排序问题
2017-03-24 11:00
447 查看
最近使用SQL语句进行UNION查询,惊奇的发现:SQL没问题,UNION查询也没问题,都可以得到想要的结果,可是在对结果进行排序的时候,却出问题了。
1.UNION查询没问题
2.排序就出问题了
3.创建临时表
使用类似于创建临时表的方法保存查询结果,然后对临时表进行查询排序。
4.起别名
不知道为什么第3步中查询依旧没有,然后对UNION查询的结果起个别名,然后再查询排序就没问题了。
查出来就好说了,再进行去重或者其他操作,也没问题.
SELECT DISTINCT a.id,a.username,a.mobile,FROM_UNIXTIME(a.time,'%Y/%m/%d') as _time,a.leader
FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader
FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1
UNION ALL
SELECT leadorderid,username,mobile,time,null
FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23
) AS a
ORDER BY time DESC
1.UNION查询没问题
SELECT `id`,`username`,`mobile`,`time`,id AS leader FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1 UNION ALL SELECT leadorderid,username,mobile,time,null FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23结果如下
2.排序就出问题了
SELECT `id`,`username`,`mobile`,`time`,id AS leader FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1 ORDER BY time DESC UNION ALL SELECT leadorderid,username,mobile,time,null FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23 ORDER BY time DESC执行这条SQL语句之后就报错。
3.创建临时表
使用类似于创建临时表的方法保存查询结果,然后对临时表进行查询排序。
SELECT id,username,mobile,time,leader FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1 UNION ALL SELECT leadorderid,username,mobile,time,null FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23 ) ORDER BY time DESC
4.起别名
不知道为什么第3步中查询依旧没有,然后对UNION查询的结果起个别名,然后再查询排序就没问题了。
SELECT a.id,a.username,a.mobile,a.time,a.leader FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1 UNION ALL SELECT leadorderid,username,mobile,time,null FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23 ) AS a ORDER BY time DESC结果就正确了
查出来就好说了,再进行去重或者其他操作,也没问题.
SELECT DISTINCT a.id,a.username,a.mobile,FROM_UNIXTIME(a.time,'%Y/%m/%d') as _time,a.leader
FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader
FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1
UNION ALL
SELECT leadorderid,username,mobile,time,null
FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23
) AS a
ORDER BY time DESC
相关文章推荐
- [唐胡璐] - SQL UNION All 排序问题
- [唐胡璐] - SQL UNION All 排序问题
- SQL用了Union后的排序问题
- SQL 2000 UNION ALL 子查询增加排序列报错问题
- SQL 问题:已知主键id 和排序条件 这条记录的上一条或下一条记录
- 关于sql语句group by 排序问题~
- 字符串的排序问题(SQL)
- 有关SQL排序规则---------即"无法解决 equal to 操作的排序规则冲突"等等的菜问题.
- SQL的一个排序问题
- Sql常见问题总结二(Sql语句怎么样查询IP,游标去重复,各种函数使用,各种取时间格式,字符串精确排序,超时锁问题)
- ORACLE SQL的隐式排序问题
- 解决一个union多表排序查询问题
- 利用动态SQL解决排序问题
- SQL中union和多个order by同时出现的问题
- SQL分页排序的实现与分页数据重复问题——以Oracle rownum为例
- Oracle Union/Union all 的排序问题
- 有关SQL排序规则---------即"无法解决 equal to 操作的排序规则冲突"等等的菜问题.
- SQL中 union问题
- 一个关于时间的SQL分组排序问题
- union小计,大计,排序问题