zoukankan      html  css  js  c++  java
  • 关于Union和Union All的区别以及用法

          有些时候我们在查询的时候会碰到这么一个问题,就是一条SQL不能查出来你想要的结果;首先,我们必须明确一条查询SQL执行之后数据库会给我们返回什么,他会返回符合条件的一个结果集,而当你一条查询SQL不能解决的时候,就可以用两条SQL去把两个结果集拼出来,但是必须要保证两个SQL的列名和个数一致.那么这个时候我们就需要用到Unicon All或者Union了

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

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

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

    例如: 

    select employee_id,job_id from employees 
    union 
    select employee_id,job_id from job_history 

    以上将两个表的结果联合在一起。这两个例子会将两个select语句的结果中的重复值进行压缩,也就是结果的数据并不是两条结果的条数的和。如果希望即使重复的结果显示出来可以使用union all,例如: 

    2.在oracle的scott用户中有表emp 
    select * from emp where deptno >= 20 
    union all 
    select * from emp where deptno <= 30 
    这里的结果就有很多重复值了。 

    有关union和union all关键字需要注意的问题是: 

    union 和 union all都可以将多个结果集合并,而不仅仅是两个,你可以将多个结果集串起来。 
    使用union和union all必须保证各个select 集合的结果有相同个数的列,并且每个列的类型是一样的。但列名则不一定需要相同,oracle会将第一个结果的列名作为结果集的列名。例如下面是一个例子: 
    select empno,ename from emp 
    union 
    select deptno,dname from dept 
    我们没有必要在每一个select结果集中使用order by子句来进行排序,我们可以在最后使用一条order by来对整个结果进行排序。例如: 
    select empno,ename from emp 
    union 
    select deptno,dname from dept 
    order by ename;

  • 相关阅读:
    Google Shell Style Guide
    50 Must-have plugins for extending Twitter Bootstrap
    HTTP 请求头中的 X-Forwarded-For
    如何让 PowerPoint 幻灯片「高大上」?
    数据挖掘系列(1)关联规则挖掘基本概念与Aprior算法
    关于大型网站技术演进的思考(三)--存储的瓶颈(3)
    基于 Nginx XSendfile + SpringMVC 进行文件下载
    如何成为全栈工程师?
    Sqlserver通过列名查表名
    animate
  • 原文地址:https://www.cnblogs.com/chao538/p/5431056.html
Copyright © 2011-2022 走看看