sql union和union all的用法及效率


一:Union指令的目的是將兩個sql語句的結果合並起來。

假設我們有以下的兩個表格: 
Store_Information 表: store_name      Sales      Date 


                              Los Angeles     $1500      Jan-05-1999 
                              San Diego       $250       Jan-07-1999 
                              Los Angeles     $300       Jan-08-1999 
                               Boston          $700       Jan-08-1999 


Internet Sales 表:    Date            Sales 


           Jan-07-1999     $250 
           Jan-10-1999     $535 
           Jan-11-1999     $320 
           Jan-12-1999     $750 

如果我們要找出來所有有營業額 (sales) 的日子。要達到這個目的,我們用以下的 SQL 語句: 
SELECT Date FROM Store_Information 
UNION 
SELECT Date FROM Internet_Sales 

結果: 
  Date 
  Jan-05-1999 
  Jan-07-1999 
  Jan-08-1999 
  Jan-10-1999 
  Jan-11-1999 
  Jan-12-1999 

UNION在進行表鏈接后會篩選掉重復的記錄,所以在表鏈接后會對所產生的結果集進行排序運算,刪除重復的記錄再返回結果。

 

UNION ALL 這個指令的目的也是要將兩個 SQL 語句的結果合並在一起。 UNION ALL 和 UNION 不同之處在於 UNION ALL 會將每一筆符合條件的資料都列出來,無論資料值有無重復。

如果上述的例子我們只用UNION ALL的話,則結果會是:

    Date 
  Jan-05-1999 
  Jan-07-1999 
  Jan-08-1999 
  Jan-08-1999 
  Jan-07-1999 
  Jan-10-1999 
  Jan-11-1999 
  Jan-12-1999 

 

總結:union是將具有相同結果的數據合並起來,同時會去掉所有重復的數據。

 

二:JOIN與UNION區別

join 是兩張表做交連后里面條件相同的部分記錄產生一個記錄集

union是產生的兩個記錄集(字段要一樣的)並在一起,成為一個新的記錄集。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM