以前一直不知道union和union all到底有什麼區別,今天來好好的研究一下,網上查到的結果是下面這個樣子,可是還是不是很理解,下面將自己親自驗證:
union:對兩個結果集進行並集操作,不包括重複行,同時進行預設規則的排序;
union all:對兩個結果集進行並集操作,包括重複行,不進行排序;
下面進行簡單的測試(因為是測試,所以sql**寫的很簡單,沒有什麼很嚴格的規範,只是為了理解這兩者之間的區別)
嚴格的標準寫法應該先判斷資料庫是否存在,表是否存在等等約束
第一步,建庫:
view plain
create
database
test
go
use test
go
第二步,建表:
view plain
create
table
table1
( id int
notnull
, name
varchar
(20)
notnull
) create
table
table2
( id int
notnull
, name
varchar
(20)
notnull
)
第三步,插入測試資料:
view plain
insert
into
table1
values
(1,'姚羽'
) insert
into
table1
values
(2,'邊兵兵'
) insert
into
table1
values
(3,'袁磊'
) insert
into
table2
values
(1,'姚羽'
) insert
into
table2
values
(2,'柳春平'
) insert
into
table2
values
(3,'張永超'
) insert
into
table2
values
(4,'劉華健'
)
第四步,測試開始:
view plain
select
* from
table1
select
* from
table2
執行兩個表的查詢結果如下
可以很容易的看到,上面插入的測試資料當中,有一條是重複的
那麼我們 先看執行union 看看
view plain
select * from table1
union
select * from table2
再執行union all 看看
view plain
select
* from
table1
union
allselect
* from
table2
UNION 和UNION ALL 的區別
在資料庫中,union 和union all 關鍵字都是將兩個結果集合並為乙個,但這兩者從使用和效率上來說都有所不同。union 在進行表鏈結後會篩選掉重複的記錄,所以在表鏈結後會對所產生的結果集進行排序運算,刪除重複的記錄再返回結果。實際大部分應用中是不會產生重複的記錄,最常見的是過程表與歷史表 ...
UNION和UNION ALL的區別
關鍵字 union 和union all 的區別 出處 在資料庫中,union和union all關鍵字都是將兩個結果集合並為乙個,但這兩者從使用和效率上來說都有所不同。union在進行表鏈結後會篩選掉重複的記錄,所以在表鏈結後會對所產生的結果集進行排序運算,刪除重複的記錄再返回結果。實際大部分應用...
UNION 和UNION ALL 的區別
在資料庫中,union 和union all 關鍵字都是將兩個結果集合並為乙個,但這兩者從使用和效率上來說都有所不同。union 在進行表鏈結後會篩選掉重複的記錄,所以在表鏈結後會對所產生的結果集進行排序運算,刪除重複的記錄再返回結果。實際大部分應用中是不會產生重複的記錄,最常見的是過程表與歷史表 ...