zoukankan      html  css  js  c++  java
  • SQL语句中:UNION与UNION ALL的区别

    转自:https://www.cnblogs.com/areyouready/p/7827779.html

    UNION用的比较多union all是直接连接,取到得是所有值,记录可能有重复   union 是取唯一值,记录没有重复   
    1、UNION 的语法如下:
    [SQL 语句 1]
    UNION
    [SQL 语句 2]

    2、UNION ALL 的语法如下:
    [SQL 语句 1]
    UNION ALL
    [SQL 语句 2]
    demo:在树结构中,将两个不同字段的表整合成一个查询结果输出
    select "ID","NAME","PARENT_ID","STATE","ORG_ID","VALID_FLAG","R_LEVEL" from (select t.id,t.org_name as name ,
    t.parent_org_id as parent_id,'org' as state,0 as r_level,t.id as org_id,t.valid_flag from hr_org t union all select d.id,d.dept_name as name, case d.parent_dept_id when '-1' then d.org_id else d.parent_dept_id end as parent_id,'dept' as state,
    d.dept_level as r_level,d.org_id,d.valid_flag from hr_dept d ) s
    效率:
    UNION和UNION ALL关键字都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。

    1、对重复结果的处理:UNION在进行表链接后会筛选掉重复的记录,Union All不会去除重复记录。

    2、对排序的处理:Union将会按照字段的顺序进行排序;UNION ALL只是简单的将两个结果合并后就返回。

    从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复数据且不需要排序时的话,那么就使用UNION ALL。


    简要回答:
    UNION去重且排序

    UNION ALL不去重不排序
  • 相关阅读:
    Oracle EBS json
    OAF--基础
    Oracle EBS FA 本年折旧
    Oracle EBS FA 获取累计折旧
    SOAP REST
    Oracle EBS FA 资产取值
    Java ——基础语法
    PL/SQL APIs for Concurrent Processing
    Using Globals in Oracle Reports (Doc ID 34751.1)
    Using SRW Packaged Procedures In Reports (Doc ID 61643.1)
  • 原文地址:https://www.cnblogs.com/person008/p/10375764.html
Copyright © 2011-2022 走看看