登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

飞哥的技术博客

世上无难事,只怕有心人!

 
 
 

日志

 
 
 
 

oracle union union all intersect minus的含义及区别  

2009-06-29 22:36:26|  分类: Oracle |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
oracle union union all intersect minus的含义及区别
2009-03-17 14:20

  集合操作有 并,交,差 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)   

两个表使用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

两个表使用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

两个表使用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

两个表使用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的含义及区别_陈华的个人空间----lifeneedyou
  评论这张
 
阅读(841)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018