oracle 中Union和Union all区别

news/2024/7/3 3:11:46

以前一直不知道Union和Union All到底有什么区别,今天来好好的研究一下,网上查到的结果是下面这个样子,可是还是不是很理解,下面将自己亲自验证:

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

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

 

下面进行简单的测试(因为是测试,所以sql代码写的很简单,没有什么很严格的规范,只是为了理解这两者之间的区别)

严格的标准写法应该先判断数据库是否存在,表是否存在等等约束

第一步,建库:

view plain

  1. Create database Test  
  2. go  
  3.   
  4. use Test  
  5. go  

第二步,建表:

view plain

  1. Create table Table1  
  2. (  
  3.     id int not null,  
  4.     name varchar(20) not null  
  5. )  
  6.   
  7. Create table Table2  
  8. (  
  9.     id int not null,  
  10.     name varchar(20) not null  
  11. )  

 

第三步,插入测试数据:

view plain

  1. Insert into Table1 values (1,'姚羽')  
  2. Insert into Table1 values (2,'边兵兵')  
  3. Insert into Table1 values (3,'袁磊')  
  4.   
  5. Insert into Table2 values (1,'姚羽')  
  6. Insert into Table2 values (2,'柳春平')  
  7. Insert into Table2 values (3,'张永超')  
  8. Insert into Table2 values (4,'刘华健') 

第四步,测试开始:

view plain

  1. select * from Table1  
  2. select * from Table2  

 

执行两个表的查询结果如下

可以很容易的看到,上面插入的测试数据当中,有一条是重复的

那么我们  先看执行union 看看

view plain

  1. select * from Table1  
  2. union   
  3. select * from Table2  

 

 

再执行union  all 看看

view plain

  1. select * from Table1  
  2. union all  
  3. select * from Table2  


http://www.niftyadmin.cn/n/3658790.html

相关文章

如何简单部署用VSTO SE 2005开发的Excel,Word插件

如何简单部署用VSTO SE 2005开发的Excel,Word插件 本文标题之所以要加上简单二字,是为了区别于msdn上的两篇讲述VSTO部署的经典长文。 http://msdn2.microsoft.com/en-us/library/bb332051.aspx http://msdn2.microsoft.com/en-us/library/bb332052.a…

文件上传常用绕过方式

JavaScript前端验证绕过 JavaScript 验证就是所谓的客户端验证,也是最脆弱的一种验证。直接修改数据包或禁用 JavaScript.enable 即可绕过。 例如upload的第一题,在我们点击发送时,还没经过代理就直接弹窗报错,就考虑存在前端验证…

GCC编译器的使用

原文地址:http://www.myplaces.com.cn/index.php/action/viewspace/itemid/21751看下面的例子:test.c#includemain(){ char *str"I like Linux! I advices you jion in the Linux World";printf("%s/n",str);exit(0);}使用gcc编译输入gcc -c te…

kafka-manager部署安装

一、kafka-manager 简介 为了简化开发者和服务工程师维护Kafka集群的工作,yahoo构建了一个叫做Kafka管理器的基于Web工具,叫做 Kafka Manager。这个管理工具可以很容易地发现分布在集群中的哪些topic分布不均匀,或者是分区在整个集群分布不均…

Torrent文件格式

刚找到的,不敢独享,发来看看 Torrent文件格式 BT种子文件格式 BT种子文件使用了一种叫bencoding的编码方法来保存数据。 bencoding现有四种类型的数据:srings(字符串),integers(整数),lists(列表),…

cygwin/gcc与MinGW

cygwin/gcc和MinGW都是gcc在windows下的编译环境,但是它们有什么区别?在实际工作中如何选择这两种编译器呢?cygwin/gcc完全可以和在linux下的gcc划等号,这个从boost库的划分中就可以看出来端倪,cygwin下的gcc和linux下的gcc使用的是相同的T…

kafka集群中jmx端口设置

jmx端口主要用来监控kafka集群的。 在启动kafka的脚本kafka-server-start.sh中找到堆设置,添加export JMX_PORT"9999" if [ "x$KAFKA_HEAP_OPTS" "x" ]; then export KAFKA_HEAP_OPTS"-Xmx1G -Xms1G" export JMX_PORT&…