首頁 資料庫 mysql教程 Oracle中Union与Union All的区别(适用多个数据库)

Oracle中Union与Union All的区别(适用多个数据库)

Jun 07, 2016 pm 06:07 PM
union

如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。union(或称为联合)的作用是将多个结果合并在一起显示出来

Union 与 Union ALL 的作用都是合并 SELECT 的查询结果集,那么它们有什么不同呢?
Union 将查询到的结果集合并后进行重查,将其中相同的行去除。缺点:效率低;
而Union ALL 则只是合并查询的结果集,并不重新查询,效率高,但是可能会出现冗余数据。

我们举个例子来说明一下:

比如数据库中有两张表 tab1 和 tab2。

tab1 中的数据有:

tab2 中的数据有:

执行查询:

代码如下:SELECT * FROM tab1 UNION SELECT * FROM tab2
结果如下:
如果执行如下查询:

代码如下:
SELECT * FROM tab1 UNION ALL SELECT * FROM tab2

则结果如下:
这回看出来有什么不同了吧?

union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。

Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;

Union All:对两个结果集进行并集操作,包括重复行,不进行排序;

Intersect:对两个结果集进行交集操作,不包括重复行,同时进行默认规则的排序;

Minus:对两个结果集进行差操作,不包括重复行,同时进行默认规则的排序。

可以在最后一个结果集中指定Order by子句改变排序方式。

例如:
代码如下:
select employee_id,job_id from employees
union
select employee_id,job_id from job_history

以上将两个表的结果联合在一起。这两个例子会将两个select语句的结果中的重复值进行压缩,也就是结果的数据并不是两条结果的条数的和。如果希望即使重复的结果显示出来可以使用union all,例如:

2.在oracle的scott用户中有表emp
代码如下:
select * from emp where deptno >= 20
union all
select * from emp where deptno
这里的结果就有很多重复值了。

有关union和union all关键字需要注意的问题是:

union 和 union all都可以将多个结果集合并,而不仅仅是两个,你可以将多个结果集串起来。
使用union和union all必须保证各个select 集合的结果有相同个数的列,并且每个列的类型是一样的。但列名则不一定需要相同,oracle会将第一个结果的列名作为结果集的列名。例如下面是一个例子:
代码如下:
select empno,ename from emp
union
select deptno,dname from dept

我们没有必要在每一个select结果集中使用order by子句来进行排序,我们可以在最后使用一条order by来对整个结果进行排序。例如:
代码如下:
select empno,ename from emp
union
select deptno,dname from dept
order by ename;
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

c語言union的用法 c語言union的用法 Sep 27, 2023 am 11:00 AM

c語言union的用法是一種特殊的資料類型,它允許在相同的記憶體位置儲存不同的資料類型,union的使用可以幫助我們節省記憶體空間,並且可以方便地在不同的資料類型之間進行轉換。使用union時需要注意對應的成員是有效的,並且只能同時存取一個成員。

MySQL中如何使用FULL OUTER JOIN函數取得兩個表的並集 MySQL中如何使用FULL OUTER JOIN函數取得兩個表的並集 Jul 26, 2023 pm 05:45 PM

MySQL中如何使用FULLOUTERJOIN函數取得兩個表的並集在MySQL中,FULLOUTERJOIN函數是一種融合內連接和外連接的功能強大的連接操作。它可以用來取得兩個表的並集,即將兩個表中的所有資料合併為一個結果集。本文將介紹FULLOUTERJOIN函數的用法,並提供一些範例程式碼以幫助讀者更好地理解。 FULLOUTERJOIN函數

java如何定義Union類別實作資料體的共存 java如何定義Union類別實作資料體的共存 May 14, 2023 pm 03:34 PM

定義Union類別實作資料體的共存在C/C++語言中,聯合體(union),又稱共用體,類似結構體(struct)的一種資料結構。聯合體(union)和結構體(struct)一樣,可以包含很多種資料類型和變量,兩者區別如下:結構體(struct)中所有變數是「共存」的,同時所有變數都生效,各個變數佔據不同的記憶體空間;聯合體(union)中是各變數是「互斥」的,同時只有一個變數生效,所有變數佔據同一塊記憶體空間。當多個資料需要共享記憶體或多個資料每次只取其一時,可以採用聯合體(union)。在Java

怎麼用mysql union實作全外連線查詢 怎麼用mysql union實作全外連線查詢 May 30, 2023 pm 06:49 PM

1、union不是多表格連接查詢的一種方式,將多個查詢句子的查詢結果合併成一個結果,去除重複資料。 2.全外連接查詢左表和右表的數據,然後根據連接條件連接。實例#用左外的Aunion右外的BSELECT*FROMt_categorycLEFTOUTERJOINt_productpONc.cid=p.cnounionSELECT*FROMt_categorycRIGHTOUTERJOINt_productpONc.cid=p.cno

如何透過MySQL對UNION最佳化來提高效能 如何透過MySQL對UNION最佳化來提高效能 May 11, 2023 pm 05:40 PM

在許多資料庫應用程式中,我們都會面臨需要整合來自多個資料來源的資料的情況。 MySQL的UNION語句就是一種用來解決這種情況的方式,它允許我們將兩個或多個SELECT語句的結果集合併為一個。雖然這是一個非常方便的功能,但如果不加以最佳化,UNION語句也可能會對系統產生效能問題。本文將探討如何透過MySQL對UNION最佳化來提升效能。使用UNIONALL在使用U

MySQL中怎麼用Union優化Like語句 MySQL中怎麼用Union優化Like語句 May 31, 2023 pm 03:55 PM

用Union優化Like語句1)有時候,你可能需要在查詢中使用or操作符來比較。當or關鍵字在where子句中使用頻率過高的時候,它可能會使MySQL優化器錯誤的選擇全表掃描來檢索記錄。 union子句可以是查詢執行的更快,尤其是當其中一個查詢有一個最佳化索引,而另一個查詢也有一個最佳化索引的時候。例如,在first_name和last_name上分別存在索引的情況下,執行下列查詢語句:mysql>select*fromstudentswherefirst_namelike'A

mysql使用union的注意點是什麼 mysql使用union的注意點是什麼 Jun 03, 2023 pm 08:04 PM

1.union運算子用於連接兩個以上的select語句的結果組合到一個結果集合中。多個select語句會刪除重複的資料。 2.使用時union合併結果集時,要求兩個結果集的列數相同。實例selectplayerno,townfromPLAYERSwheretown='Inglewood'unionselectplayerno,townfromPLAYERSwheretown='Plymouth';

MySQL中union和unionall差別是什麼 MySQL中union和unionall差別是什麼 May 30, 2023 am 08:04 AM

union:對多個結果集進行並集操作,不包括重複行,同時進行排序。 unionall:對多個結果集進行並集操作,包括重複行,不進行排序。查詢部門小於30號的員工信息,和部門大於20小於40號的員工資訊。 ①.先查詢部門小於30號的員工資料。 SELECTemployees_id,last_name,salary,department_idFROMemployeesWHEREdepartment_id

See all articles