zoukankan      html  css  js  c++  java
  • Oracle 中 union与union all

    如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。

    union(或称为联合)的作用是将多个结果合并在一起显示出来。

    union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。

    Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;

    Union All:对两个结果集进行并集操作,包括重复行,不进行排序;

    Intersect:对两个结果集进行交集操作,不包括重复行,同时进行默认规则的排序;

    Minus:对两个结果集进行差操作,不包括重复行,同时进行默认规则的排序。

    可以在最后一个结果集中指定Order by子句改变排序方式。

    例如:

    select employee_id,job_id from employees  

    union  

    select employee_id,job_id from job_history 

    selectemployee_id,job_id from employees

    union 

    selectemployee_id,job_id from job_history 

    以上将两个表的结果联合在一起。

    这两个例子会将两个

    select

    语句的结果中的重复值进行压缩,

    也就是结果的数据并不是两条结果的条数的和。如果希望即使重复的结果显示出来可以使用

    union all,

    例如:

    2.在oracle的scott用户中有表emp  代码 1. select * from emp where deptno >= 20 2. union all   3. select * from emp where deptno <=30 select * from emp where deptno>= 20 union all  select * from emp where deptno<= 30 

    这里的结果就有很多重复值了。

    有关union和union all关键字需要注意的问题是:union 和 union all都可以将多个结果集合并,而不仅仅是两个,你可以将多个结果集串起来。

  • 相关阅读:
    资源文件打包到Web自定义控件中应用
    .Net中的集合类
    javaScript中URL编码转换,escape() encodeURI() encodeURIComponent
    div 换行
    asp.net 清除缓存OpenShowDialog模式下
    hdu 1787 GCD Again
    ZOJ 1244
    hdu 1255 覆盖的面积
    POJ 2777 Count Color
    POJ 3750 小孩报数问题
  • 原文地址:https://www.cnblogs.com/macavalier/p/3154269.html
Copyright © 2011-2022 走看看