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

集合操作符:将两个查询的结果组合成一个结果集。

在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



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值