写sql时我们经常会遇到需要把从多张表查询的集果集进行合并。这时就用到了union。使用union或union all 时一定要保证查询的列的一致性 。不然sql会报错。字段不一致的话可以用单引号来占位。

例:

SELECT T102.CI_ID AS RES_ID,
T102.CITYPE_ID AS RESTYPE_ID,
T102.ASSET_NUMB AS RES_CODE,
'' AS RES_E_NAME,
T102.CI_NAME AS RES_NAME,
'' AS APPNAME_NAME,
'' AS ORIGINAL_ID,
T102.ASSET_BRAND AS BRAND_ID,
T102.ASSET_BRAND_NAME AS BRAND_NAME,
T102.SERIES AS SERIES_ID,
T102.SERIES_NAME AS SERIES_NAME,
T102.MODEL AS SPECMODEL_ID,
T102.MODEL_NAME AS SPECMODEL_NAME,
T102.NETWORK AS SECZONE_ID,
T102.INSTALSITE_NAME AS COMPUTERROOM_NAME,
T102.INSTALSITE AS COMPUTERROOM_ID,
T102.CABINET_NO AS CABINET_ID,
T102.CABINET_NO_NAME AS CABINET_NAME,
'' AS RES_GRADE,
'' AS IPV4_DESC,
'' AS BG_ID,
T102.RUN_CORP_CODE AS BC_ID,
T102.REMARKS AS RES_DESC,
T102.ENABLED_STATUS,
T102.DELETED_FLAG,
'' AS OSTYPE_ID,
'' AS OS_VERSION_NO,
T102.CREATED_AT,
T102.UPDATED_AT,
T102.DELETED_AT
FROM CI_T10203 T102
WHERE T102.DELETED_FLAG = 'N' --磁带库
UNION ALL
SELECT T102.CI_ID AS RES_ID,
T102.CITYPE_ID AS RESTYPE_ID,
T102.ASSET_NUMB AS RES_CODE,
'' AS RES_E_NAME,
T102.CI_NAME AS RES_NAME,
'' AS APPNAME_NAME,
'' AS ORIGINAL_ID,
T102.ASSET_BRAND AS BRAND_ID,
T102.ASSET_BRAND_NAME AS BRAND_NAME,
T102.SERIES AS SERIES_ID,
T102.SERIES_NAME AS SERIES_NAME,
T102.MODEL AS SPECMODEL_ID,
T102.MODEL_NAME AS SPECMODEL_NAME,
T102.NETWORK AS SECZONE_ID,
T102.INSTALSITE_NAME AS COMPUTERROOM_NAME,
T102.INSTALSITE AS COMPUTERROOM_ID,
T102.CABINET_NO AS CABINET_ID,
T102.CABINET_NO_NAME AS CABINET_NAME,
'' AS RES_GRADE,
'' AS IPV4_DESC,
'' AS BG_ID,
T102.RUN_CORP_CODE AS BC_ID,
T102.REMARKS AS RES_DESC,
T102.ENABLED_STATUS,
T102.DELETED_FLAG, '' AS OSTYPE_ID,
'' AS OS_VERSION_NO,
T102.CREATED_AT,
T102.UPDATED_AT,
T102.DELETED_AT FROM CI_T10204 T102
WHERE T102.DELETED_FLAG = 'N'

下面就来说明union和union all的区别

准备一张测试数据表。注意mysql中的varchar在oracle中是varchar2

drop table if exists student;
create table student
(
id int primary key,
name varchar2(50) not null,
score number not null
);
insert into student values(1,'Aaron',78);
insert into student values(2,'Bill',76);
insert into student values(3,'Cindy',89);
insert into student values(4,'Damon',90);
insert into student values(5,'Ella',73);
insert into student values(6,'Frado',61);
insert into student values(7,'Gill',99);
insert into student values(8,'Hellen',56);
insert into student values(9,'Ivan',93);
insert into student values(10,'Jay',90);
commit;
select * from student where id < 4
union
select * from student where id > 2 and id < 6
--查询结果为

1    Aaron    78
2    Bill     76
3    Cindy    89
4    Damon    90
5    Ella     73

select * from student where id < 4
union all
select * from student where id > 2 and id < 6
--查询结果为

1    Aaron    78
2    Bill    76
3    Cindy    89
3    Cindy    89
4    Damon    90
5    Ella    73

由此可以看出union和union all的区别在于对重复数据的处理。

  union 在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的集果集进行排序运算,删除重复的记录再返回结果集。实际使用时大部分是不会产生重复的记录。

  union all只是简单的将两个结果合并就返回。如果返回的结果集中有重复的数据,那么返回的结果集中就包含有重复数据。

  从性能上讲union all 要比union快很多,它没有排序去重的耗时。如果表数据量很大,并且可以确定合并的结果集中不会包含重复数据的话。就使用union all.

  我一般使用union all.真出现重复数据了再检查一下。

sql中UNION和UNION ALL的区别的更多相关文章

  1. LINQ to SQL 中 Concat、Union、Intersect、Except 方法的使用

    Ø  前言 LINQ to SQL 中需要对两个或多个数据集进行操作,比如:合并.取交集等,主要使用下面四个方法,这四个方法都是 System.Linq.IQueryable<out T> ...

  2. SQL中intersect、union、minus和except 运算符

    1.intersect运算符intersect运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表.当 ALL 随 INTERSECT 一起使用时 (inte ...

  3. SQL中的Join和Where的区别

    一.sql语句中left join.inner join中的on与where的区别 0.各种join操作的概念和作用 left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录. ...

  4. SQL中join和cross join的区别

    SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例, ...

  5. SQL中instr和like的使用区别

    1.instr函数 instr函数是一个字符串处理函数,它在Oracle/PLSQL中是返回子字符串在源字符串中的位置,如果在源串中没有找到子串,则返回0. instr函数定义如下: /* * 返回子 ...

  6. SQL中distinct 和 row_number() over() 的区别及用法

    1 前言 在咱们编写 SQL 语句操作数据库中的数据的时候,有可能会遇到一些不太爽的问题,例如对于同一字段拥有相同名称的记录,我们只需要显示一条,但实际上数据库中可能含有多条拥有相同名称的记录,从而在 ...

  7. SSM框架的sql中参数注入(#和$的区别)

    <select id="findUsersByUserName2" resultType="java.util.Map" parameterType=&q ...

  8. Access与SQL中的IsNull(),IS NULL的区别

    Access也有IsNull函数,但意义和参数却和T-SQL中的不同. 在T-SQL(也就是SQL Server所支持的SQL语言)中,IsNull的作用是把空值替代成指定的值.然而在Access中, ...

  9. Sql中的并(UNION)、交(INTERSECT)、差(minus)、除去(EXCEPT)详解

    UNION 查询选修了180101号或180102号课程或二者都选修了的学生学号.课程号和成绩. (SELECT  学号, 课程号, 成绩 FROM   学习 WHERE   课程号='180101' ...

  10. SQL中SET和SELECT赋值的区别

    最近的项目写的SQL比较多,经常会用到对变量赋值,而我使用SET和SELECT都会达到效果. 那就有些迷惑,这两者有什么区别呢?什么时候哪该哪个呢? 经过网上的查询,及个人练习,总结两者有以下几点主要 ...

随机推荐

  1. <Android 应用 之路> MPAndroidChart~BarChart

    简介 MPAndroidChart是PhilJay大神给Android开发者带来的福利.MPAndroidChart是一个功能强大并且使用灵活的图表开源库,支持Android和IOS两种,这里我们暂时 ...

  2. Docker网络管理机制实例解析+创建自己Docker网络

    实例解析Docker网络管理机制(bridge network,overlay network),介绍Docker默认的网络方式,并创建自己的网络桥接方式,将开发的容器添加至自己新建的网络,提高Doc ...

  3. OGC 的 WMS、WFS 及WCS服务(转)

    OGC——Open Geospatial Consortium——开放地理信息联盟,是一个非盈利的志愿的国际标准化组织,引领着空间地理信息标准及定位基本服务的发展目前在空间数据互操作领域,基于公共接口 ...

  4. Visual Studio Code调试electron主进程

    Visual Studio Code调试electron主进程 作者: jekkay 分类: electron 发布时间: 2017-06-11 14:56  一·概述 此文原出自[水滴石]: htt ...

  5. scp 上传和下载文件

    mac和linux自带scp命令,windows的话请考虑gitbash或者专业linux工具 (默认端口为22,所以-p可不写) 上传文件 scp -p /home/lnmp.gz root@ip: ...

  6. SVNKit学习——wiki+简介(二)

    这篇文章是参考SVNKit官网在wiki的文档,做了个人的理解~ 首先抛出一个疑问,Subversion是做什么的,SVNKit又是用来干什么的? 相信一般工作过的同学都用过或了解过svn,不了解的同 ...

  7. 一、WPF 2个datagrid之间同步进度条

    页面代码 <Grid DockPanel.Dock="Left" Width="400"> <DataGrid Name="dgSo ...

  8. 打通 Spark 系统运行内幕机制循环流程

    本课主题 打通 Spark 系统运行内幕机制循环流程 引言 通过 DAGScheduelr 面向整个 Job,然后划分成不同的 Stage,Stage 是从后往前划分的,执行的时候是從前往后执行的,每 ...

  9. 如何在SAP C4C里使用ABSL消费第三方Restful API

    首先我们得有一个可以正常工作的Restful API: 然后在Cloud for Customer的Cloud Application Studio里创建Restful API的模型,把第一步可以正常 ...

  10. hdu-2841 Visible Trees---容斥定理

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2841 题目大意: N*M的格点上有树,从0,0点可以看到多少棵树. 解题思路: 发现如果A1/B1= ...