前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL用了Union后的排序问题

SQL用了Union后的排序问题

作者头像
全栈程序员站长
发布2022-07-07 09:28:02
1.2K0
发布2022-07-07 09:28:02
举报
文章被收录于专栏:全栈程序员必看

最近使用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

结果如下

SQL用了Union后的排序问题
SQL用了Union后的排序问题

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

结果就正确了

SQL用了Union后的排序问题
SQL用了Union后的排序问题

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

    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

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/113608.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年10月,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档