黑马程序员技术交流社区

标题: ❶ 黑马日记一:数据库学习实例演练求解 SQL 中union和union all [打印本页]

作者: yy312232557    时间: 2011-11-5 23:33
标题: ❶ 黑马日记一:数据库学习实例演练求解 SQL 中union和union all
本帖最后由 yy312232557 于 2011-11-7 22:12 编辑

------------- Windows phone 手机开发ASP .NET培训、期待与您交流!----------------

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

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


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

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

第一步,建库:
  1. Create database Test
  2. go

  3. use Test
  4. go
复制代码
第二步,建表:
  1. Create table Table1
  2. (
  3. id int not null,
  4. name varchar(20) not null
  5. )

  6. Create table Table2
  7. (
  8. id int not null,
  9. name varchar(20) not null
  10. )
复制代码
第三步,插入测试数据:
  1. Insert into Table1 values (1,'姚羽')
  2. Insert into Table1 values (2,'边兵兵')
  3. Insert into Table1 values (3,'袁磊')

  4. Insert into Table2 values (1,'姚羽')
  5. Insert into Table2 values (2,'柳春平')
  6. Insert into Table2 values (3,'张永超')
  7. Insert into Table2 values (4,'刘华健')
复制代码
第四步,测试开始:
select * from Table1select * from Table2执行两个表的查询结果如下


可以很容易的看到,上面插入的测试数据当中,有一条是重复的
那么我们 先看执行union 看看
  1. select * from Table1
  2. union
  3. select * from Table2
复制代码


再执行union all 看看
  1. select * from Table1
  2. union all
  3. select * from Table2
复制代码


相信到此时,应该明白了union 和 union all 的区别了, 我以前也一直没搞清楚,这次看视频,就终于搞清楚了, 如果我有不对的地方希望大家拍砖。


------------- Windows phone 手机开发ASP .NET培训、期待与您交流!----------------


作者: yy312232557    时间: 2011-11-5 23:41
这里为什么不让我编辑啊???我还有点东西没说完呢,保存了就回不去了{:soso_e101:}
作者: 夏雪锐    时间: 2011-11-6 08:12
{:soso_e179:}
作者: 夏雪锐    时间: 2011-11-6 19:49
晕,日记都写到这儿来了

作者: 郑文    时间: 2011-11-7 19:18
恩 继续加油 简单的理解了 难的也就不难了




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2