集合操作有 并,交,差 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
来自:http://www.douban.com/note/154030850/