一、union与union all

首先建两个view

create or replace view test_view_1 as
select 1 as a, 1 as b, 1 as c from dual
union
select 2 as a, 2 as b, 2 as c from dual
union
select 3 as a, 3 as b, 3 as c from dual ;
-----
create or replace view test_view_2 as
select 4 as a, 4 as b, 4 as c from dual
union
select 3 as a, 3 as b, 3 as c from dual
union
select 2 as a, 2 as b, 2 as c from dual
order by a desc, b desc, c desc;
-- 注意:这个地方特意将test_view_2中的数据做了倒序排列

首先,看一下union的结果:

select * from test_view_1
union
select * from test_view_2;

结果如下:

然后,再看一下union all的结果:

select * from test_view_1
union all
select * from test_view_2;

结果如下:

从以上两个查询结果中,我们可以得到这样两个结论:
(1)union后的结果会自动去除数据重复的记录;而union all的结果会保留所有的数据。
(2)union后的结果会默认按照各字段的数据进行升序排序,各select本身的sort将会被忽略掉;而union all的结果不会进行排序,是单纯根据union all前后的结果顺序直接显示。

注:需要注意的一点,如果要对union或者union all的最终结果进行排序,那么需要在最后一个select语句上增加order by 才能对整个union或union all的结构起到排序作用

二、intersect和minus
1、子查询结果的列字段相同
这里我们依然使用上面的test_view_1和test_view_2这两个视图,同时还增加第三个视图

----- 新建视图
create or replace view test_view_3 as
select 3 as a, 3 as b, 3 as c from dual
union
select 4 as a, 4 as b, 4 as c from dual ;
select * from test_view_3;

看一下intersect的结果:

select * from test_view_1
intersect
select * from test_view_2;

结果如下:

从结果上,我们可以看到,intersect取了两个结果集的并集。

然后,我们再来看一下minus的结果:

select * from test_view_1
minus
select * from test_view_2 ;

结果如下:

从结果上,可以看到,只有一条记录返回,而且这条记录是第一个视图test_view_1中的数据。

然后我们再做一个minus的实验:

select * from test_view_1
minus
select * from test_view_3;

结果如下:

从结果上来看,依然只有第一个结果集(test_view_1)中的差显示出来,第二个结果集(test_view_3)中的记录4没有显示出来。

这时,我们就有一个疑问了:minus是做上下两个结果集的差,为什么结果中只有第一个视图的数据,而没有第二个视图的数据呢?

因为SQL中,minus做了如下处理:
如果两个查询结果集中有数据不相同的记录时(即存在差),将只显示第一个结果集中的差值记录,第二个结果集中的不一样的记录将被剔除。

那么,和minus相反的intersect取交集,是否也有同样的处理机制呢?可以做一个实验看一下。
首先创建新的视图,将数据做一下修改:

create or replace view test_view_4 as
select 2 as b, 2 as c, 2 as d from dual
union
select 3 as b, 3 as c, 3 as d from dual
union
select 4 as b, 4 as c, 4 as d from dual ;
-------- create or replace view test_view_5 as
select 2 as a, 2 as b, 2 as c, 2 as d from dual
union
select 3 as a, 3 as b, 3 as c, 3 as d from dual
union
select 4 as a, 4 as b, 4 as c, 4 as d from dual ; -------
create or replace view test_view_6 as
select 'char1' as a, 'char1' as b, 'char1' as c from dual
union
select 'char2' as a, 'char2' as b, 'char2' as c from dual
union
select 'char3' as a, 'char3' as b, 'char3' as c from dual ;

在test_view_4中,有三个column列,但是列名不再是a b c,而是改成了b c d ;
在test_view_5中,在已有的a b c三列基础上,又新增了第四列d ;
在test_view_6中,a b c三列的数据类型不再是number型,而是char字符型。

看一下test_view_1和test_view_4的intersect交集后的结果:

select a,b,c from test_view_1
intersect
select b,c,d from test_view_4 ;

执行结果如下:

从以上结果可以看出,intersect在两个结果集的列名不同的情况下,也是取了第一个结果集中的数据进行显示(a b c),第二个结果集(test_view_4)中虽然d列也有数据和第一个结果集(test_view_1)的数据相同,但依然被intersect给剔除掉了。

接下来,测试一下,intersect是否会自动排序

select a,b,c from test_view_1
intersect
select a,b,c from test_view_2 ;

执行结果如下:

根据上面的结果,得出结论:intersect两各结果集最后也是会自动升序排序。

然后再执行以下实验:

select a,b,c from test_view_1
intersect
select a,b,c,d from test_view_5 ;

执行结果如下:
提示出错: ORA-01789: 查询块具有不正确的结果列数

select a,b,c from test_view_1
intersect
select a,b,c from test_view_6 ;

执行结果如下:
提示出错:ORA-01790: 表达式必须具有与对应表达式相同的数据类型

从上述两个实验可以得出一个结论:intersect前后的结果集的列数 the number of columns 和 列字段的数据类型 the type of columns必须上下一致,否则执行失败。
minus和intersect一样,也是有这样的限制,这里不再做实验记录。

【oracle】union、union all、intersect、minus 的用法及区别的更多相关文章

  1. ORACLE中union/union all/Intersect/Minus用法

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

  2. Oracle中的Union、Union All、Intersect、Minus

    Oracle中的Union.Union All.Intersect.Minus  众所周知的几个结果集集合操作命令,今天详细地测试了一下,发现一些问题,记录备考. 假设我们有一个表Student,包括 ...

  3. oracle之集合操作函数---minus、union、intersect

    集合操作符专门用于合并多条select语句的结果,包括:UNION,UNION ALL,INTERSECT,MINUS.当使用集合操作函数时,需保证数据集的字段数据类型和数目一致. 使用集合操作符需要 ...

  4. Oracle SQL Lesson (8) - 使用集合操作符(Union,Intersect,Minus)

    集合操作符UNION/UNION ALLINTERSECTMINUS Union All不排序,不去重,其余均升序且去重.create table e1 as select * from emp wh ...

  5. Oracle中的Union、Union All、Intersect、Minus[转]

    众所周知的几个结果集集合操作命令,今天详细地测试了一下,发现一些问题,记录备考. 假设我们有一个表Student,包括以下字段与数据: drop table student; create table ...

  6. Union、Union All、Intersect、Minus用法和区别

    假设我们有一个表Student,包括以下字段与数据: [c-sharp] view plain copydrop table student;    create table student  (   ...

  7. Union、Union All、Intersect、Minus

    转自:http://www.2cto.com/database/201208/148795.html Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序: Union All: ...

  8. 集合操作符 Union / Union All / Intersect / Minus

    集合操作符 Union / UnionAll / Intersect / Minus -- 生成测试数据 create table dept_01 as select * from dept wher ...

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

    Oracle中Union与Union All的区别(适用多个数据库) 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或 ...

随机推荐

  1. jvm--3.内存管理

    5.JVM内存管理 JAVA虚拟机在执行java程序的过程中,会把它管理的内存分成若干个不同的数据区域. ----------------------------------------------- ...

  2. node.js下使用RSA加密事例(windows)

    1.安装openss 直接下载window下的安装包 http://houjixin.blog.163.com/blog/static/3562841020144143494875/ 以我发博文现在的 ...

  3. phpcurl类

    1.需求 了解curl的基本get和post用法 2.例子 <?php class Curl{ private $timeout=30; public function set_timeout( ...

  4. java常用工具

    /** * 将字节数组转换成字符串 * @param array 字节数组 * @return String */ public static String byte2str(byte[] array ...

  5. [BZOJ3729]Gty的游戏

    [BZOJ3729]Gty的游戏 试题描述 某一天gty在与他的妹子玩游戏.妹子提出一个游戏,给定一棵有根树,每个节点有一些石子,每次可以将不多于L的石子移动到父节点,询问将某个节点的子树中的石子移动 ...

  6. angular路由详解:

    1.$routeProvider ngRoute模块中的服务 2.otherwise:设置用于路由改变时,与任何其他定义的路由无法匹配的时候执行的代码 3.when:为$route服务定义新的路由 例 ...

  7. Hadoop学习记录

    http://blog.csdn.net/m_star_jy_sy/article/details/26476907配置windows里eclipse连接hadoop集群 hadoop常见命令 启动H ...

  8. Euler Tour Tree与dynamic connectivity

    Euler Tour Tree最大的优点就是可以方便的维护子树信息,这点LCT是做不到的.为什么要维护子树信息呢..?我们可以用来做fully dynamic connectivity(online) ...

  9. asp.net 文件下载(txt,rar,pdf,word,excel,ppt)

    aspx 文件下载说起来一点都不难,但是在做的过程中还是遇到了一些小小的问题,就是因为这些小小的问题,导致解决起来实在是太难了,其中一个就是Response.End();导致下载文件出现线程终止的情况 ...

  10. Oracle 在线重定义表分区

    ==================原始表================原始表=====================原始表 create table BUILDING_temp(building ...