您的位置:首页 > 数据库 > Oracle

SQL集合操作符的用法(Oracle中)

2013-05-15 15:50 337 查看
集合操作符:将两个查询的结果组合成一个结果集。

在Oracle中有两张表

表A no 表B no

1 1

2 4

3

1. UNION(联合)

UNION操作符返回两个查询选定的所有不重复的行。

SQL> SELECT no FROM A

UNION

SELECT no FROM B;

结果:

no

1

2

3

4

2. UNION ALL(联合所有)

合并两个查询选定的所有行,包括重复的行。

上面SQL语句,把 UNION 改为 UNION ALL

结果:

no

1

2

3

1

4

3. INTERSECT(交集)

返回两个查询都有的行。

上面SQL语句,把 UNION 改为 INTERSECT

结果:

no

1

4. MINUS(减集)

返回第一个查询选定但是没有被第二个查询选定的行。

上面SQL语句,把 UNION 改为 MINUS

结果:

no

2

3

======================================================

集合操作有 并,交,差 3种运算。

 union :得到两个查询结果的并集,并且自动去掉重复行。不会排序

 union all:得到两个查询结果的并集,不会去掉重复行。也不会排序

 intersect:得到两个查询结果的交集,并且按照结果集的第一个列进行排序

 minus:得到两个查询结果的减集,以第一列进行排序

例子:

  下面是两个表:一个主修课程表,一个选修课程表。

这个是主修课程表:minors

   create table minors(

 minor_id number primary key,

  minor_name varchar2(30) not null,

  credit_hour number(2)

  )

插入3条记录:               

   insert into minors values(10101,'计算机原理',4)

  insert into minors values(10201,'自动控制原理',3)

  insert into minors values(10301,'工程制图原理',4)

下面创建选修课程表minors2

  create table minors2(

minor_id number primary key,

minor_name varchar2(30) not null,

credit_hour number(2)

)

插入两条记录:

insert into minors2 values(10201,'自动控制原理',3)

insert into minors2 values(10301,'工程制图原理',4)
(1)

两个表使用union all:得到如下结果

select minor_id,minor_name,credit_hour from minors union all

select minor_id,minor_name,credit_hour from minors2 order by credit_hour

结果:

MINOR_ID MINOR_NAME CREDIT_HOUR

---------- ------------------------------ -----------

10201 自动控制原理 3

10201 自动控制原理 3

10101 计算机原理 4

10301 工程制图原理 4

10301 工程制图原理 4
(2)

两个表使用union :得到如下结果

select minor_id,minor_name,credit_hour from minors union

select minor_id,minor_name,credit_hour from minors2 order by credit_hour

结果:

MINOR_ID MINOR_NAME CREDIT_HOUR

---------- ------------------------------ -----------

10201 自动控制原理 3

10101 计算机原理 4

10301 工程制图原理 4
(3)

两个表使用intersect :得到如下结果

select minor_id,minor_name,credit_hour from minors intersect

select minor_id,minor_name,credit_hour from minors2

结果:

MINOR_ID MINOR_NAME CREDIT_HOUR

---------- ------------------------------ -----------

10201 自动控制原理 3

10301 工程制图原理 4
(4)
两个表使用minus :得到如下结果

select minor_id,minor_name,credit_hour from minors minus

select minor_id,minor_name,credit_hour from minors2

结果:

MINOR_ID MINOR_NAME CREDIT_HOUR

---------- ------------------------------ -----------

10101 计算机原理 4
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: