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
在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
相关文章推荐
- Oracle 集合操作符 UNION/UNION ALL/INTERSECT/MINUS的用法
- Oracle Class2. SQL查询和SQL函数(Oracle数据类型,ddl,dml,dcl,事务控制语言tcl,sql操作符,sql函数,select语句,运算符,分析函数,临时表)
- oracle_sql的用法?
- ORACLE PL/SQL开发--bulk collect的用法
- ORACLE SQL总结一:集合函数和多表查询
- Oracle 10g复合数据类型pl/sql集合学习六——索引表、嵌套表、变长数组
- (转)sql多表查询,Oracle、mysql的用法区别
- oracle 的sql语句:alter table XX add XX,用法
- oracle中SQL语句的一些有效常用用法
- oracle常用sql语句集合
- sql语句中select top n与oracle的rownum与mysql的limit用法
- Oracle集合的基本用法
- 项目中的sql语句涉及到取集合时(即in(...))的用法foreach
- oracle sql insert all 的用法 例子
- 不定时更新自己用到的oracle 比较有用的sql语句和函数用法
- oracle 集合变量以及自定义异常的用法
- [转贴]Oracle集合的用法
- 常见Oracle HINT的用法 SQL优化
- oracle中 sql语句:start with .. connect by prior.. 用法
- oracle中SQL语句的一些有效常用用法