1. 程式人生 > >Oracle中使用了Union後的排序問題

Oracle中使用了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. UNIONALL
  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. ORDERBYtimeDESC
  5. UNIONALL
  6. SELECT leadorderid,username,mobile,time,null
  7. FROM `grouporder_partner`  
  8. WHERE courseid=21 and status=1 and merchid=23   
  9. ORDERBYtimeDESC
執行這條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.     UNIONALL
  5.     SELECT leadorderid,username,mobile,time,null
  6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
  7. )   
  8. ORDERBYtimeDESC
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.     UNIONALL
  5.     SELECT leadorderid,username,mobile,time,null
  6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
  7. AS a   
  8. ORDERBYtimeDESC
結果就正確了

查出來就好說了,再進行去重或者其他操作,也沒問題.

  1. SELECTDISTINCT 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.     UNIONALL
  5.     SELECT leadorderid,username,mobile,time,null
  6.     FROM `grouporder_partner` WHERE courseid=21 and status=1 and merchid=23  
  7. AS a   
  8. ORDERBYtimeDESC