zoukankan      html  css  js  c++  java
  • SQL用了Union后的排序问题

    最近使用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
  • 相关阅读:
    移动端应用rem定义相对长度单位
    ionic4(angular) 生成browser平台的(webApp)在手机QQ浏览器不更新页面
    解决 git bash命令行执行git命令一直报错 segmentation fault
    MACBOOK OSX升级到10.15.3 Catalina 后 photoshop CS6(32位)不能用了
    自制操作系统笔记-第三章
    自制操作系统笔记-第2章
    自制操作系统笔记-第一章
    Vue学习笔记
    解决 MAC 终端上每次打开新窗口手动执行source ~/.bash_profile导出环境变量
    HTTPS的安全性
  • 原文地址:https://www.cnblogs.com/lxwphp/p/8328809.html
Copyright © 2011-2022 走看看