SQL用了Union后的排序问题

举报
lxw1844912514 发表于 2022/03/27 02:12:02 2022/03/27
【摘要】 最近使用SQL语句进行UNION查询,惊奇的发现:SQL没问题,UNION查询也没问题,都可以得到想要的结果,可是在对结果进行排序的时候,却出问题了。 1.UNION查询没问题 [sql] view plain copy SELECT `id`...

最近使用SQL语句进行UNION查询,惊奇的发现:SQL没问题,UNION查询也没问题,都可以得到想要的结果,可是在对结果进行排序的时候,却出问题了。

1.UNION查询没问题

  1. SELECT `id`,`username`,`mobile`,`time`,id AS leader   
  2. FROM `grouporder_leader`   
  3. WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1   
  4. UNION ALL   
  5. SELECT leadorderid,username,mobile,time,null   
  6. FROM `grouporder_partner`  
  7. WHERE courseid=21 and status=1 and merchid=23  

结果如下


2.排序就出问题了

  1. SELECT `id`,`username`,`mobile`,`time`,id AS leader   
  2. FROM `grouporder_leader`  
  3. WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1   
  4. ORDER BY time DESC   
  5. UNION ALL   
  6. SELECT leadorderid,username,mobile,time,null   
  7. FROM `grouporder_partner`  
  8. WHERE courseid=21 and status=1 and merchid=23   
  9. ORDER BY time DESC  

执行这条SQL语句之后就报错。

3.创建临时表

使用类似于创建临时表的方法保存查询结果,然后对临时表进行查询排序。

  1. SELECT id,username,mobile,time,leader   
  2. FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader   
  3.     FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1   
  4.     UNION ALL   
  5.     SELECT leadorderid,username,mobile,time,null   
  6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
  7. )   
  8. ORDER BY time DESC  


4.起别名

不知道为什么第3步中查询依旧没有,然后对UNION查询的结果起个别名,然后再查询排序就没问题了。

  1. SELECT a.id,a.username,a.mobile,a.time,a.leader   
  2. FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader   
  3.     FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1   
  4.     UNION ALL   
  5.     SELECT leadorderid,username,mobile,time,null   
  6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
  7. AS a   
  8. ORDER BY time DESC  

结果就正确了

查出来就好说了,再进行去重或者其他操作,也没问题.

    1. SELECT DISTINCT a.id,a.username,a.mobile,FROM_UNIXTIME(a.time,'%Y/%m/%d') as _time,a.leader   
    2. FROM (SELECT `id`,`username`,`mobile`,`time`,id AS leader   
    3.     FROM `grouporder_leader` WHERE `courseid` = 21 AND `merchid` = 23 AND `status` = 1   
    4.     UNION ALL   
    5.     SELECT leadorderid,username,mobile,time,null   
    6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
    7. AS a   
    8. ORDER BY time DESC

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100028651

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。