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都可以将多个结果集合并,而不仅仅是两个,你可以将多个结果集串起来。

  • 相关阅读:
    JavaWeb--HttpSession案例
    codeforces B. Balls Game 解题报告
    hdu 1711 Number Sequence 解题报告
    codeforces B. Online Meeting 解题报告
    ZOJ 3706 Break Standard Weight 解题报告
    codeforces C. Magic Formulas 解题报告
    codeforces B. Sereja and Mirroring 解题报告
    zoj 1109 Language of FatMouse 解题报告
    hdu 1361.Parencodings 解题报告
    hdu 1004 Let the Balloon Rise 解题报告
  • 原文地址:https://www.cnblogs.com/macavalier/p/3154269.html
Copyright © 2011-2022 走看看