1.UNION的作用

 UNION 指令的目的是将两个 SQL 语句的结果合并起来。从这个角度来看, UNION 跟 JOIN 有些许类似,因为这两个指令都可以由多个表格中撷取资料。 UNION 的一个限制是两个 SQL 语句所产生的栏位需要是同样的资料种类。另外,当我们用 UNION这个指令时,我们只会看到不同的资料值 (类似 SELECT DISTINCT)。 union只是将两个结果联结起来一起显示,并不是联结两个表………… UNION 的语法如下: [SQL 语句 1]
  假设我们有以下的两个表格,Store_Information 表格
    store_name  Sales  Date
  Los Angeles $1500 Jan-05-1999
  San Diego   $250   Jan-07-1999
  Los Angeles $300  Jan-08-1999
  Boston         $700  Jan-08-1999
 
  Internet Sales 表格
  Date              Sales
  Jan-07-1999 $250
  Jan-10-1999 $535
  Jan-11-1999 $320
  Jan-12-1999 $750
 
 而我们要找出来所有有营业额 (sales) 的日子。要达到这个目的,我们用以下的 SQL 语句:
  SELECT Date FROM Store_Information UNION SELECT Date FROM Internet_Sales 结果: Date
   Jan-05-1999
   Jan-07-1999
   Jan-08-1999
   Jan-10-1999
   Jan-11-1999
   Jan-12-1999
有一点值得注意的是,如果我们在任何一个 SQL 语句 (或是两句都一起) 用 "SELECT DISTINCT Date" 的话,那我们会得到完全一样的结果。

2. Union All
UNION ALL 这个指令的目的也是要将两个 SQL 语句的结果合并在一起。 UNION ALL 和 UNION 不同之处在于 UNION ALL 会将每一笔符合条件的资料都列出来,无论资料值有无重复。 UNION ALL 的语法如下: [SQL 语句 1]

同样假设我们有以下两个表格, Store_Information 表格
    store_name  Sales  Date
  Los Angeles $1500 Jan-05-1999
  San Diego   $250   Jan-07-1999
  Los Angeles $300  Jan-08-1999
  Boston         $700  Jan-08-1999
 
  Internet Sales 表格
  Date              Sales
  Jan-07-1999 $250
  Jan-10-1999 $535
  Jan-11-1999 $320
  Jan-12-1999 $750
 
 而我们要找出有店面营业额以及网络营业额的日子。要达到这个目的,我们用以下的 SQL 语句:
  SELECT Date FROM Store_Information UNION ALL SELECT Date FROM Internet_Sales 结果: Date
  Jan-05-1999
  Jan-07-1999
  Jan-08-1999
  Jan-08-1999
  Jan-07-1999
  Jan-10-1999
        Jan-11-1999
        Jan-12-1999

3.更多sql示例
   --合并重复行
 select * from A
 union
 select * from B
 
 
 --不合并重复行
 select * from A
 union all
 select * from B
 
 
 按某个字段排序
 --合并重复行
 select *
 from (
 select * from A
 union
 select * from B) AS T
 order by 字段名
 
 --不合并重复行
 select *
 from (
 select * from A
 union all
 select * from B) AS T
 order by 字段名

//sql server(WINDOWS平台上强大的数据库平台)版
  Select * From (
  select top 2 id,adddate,title,url from bArticle where ClassId='1' order by adddate desc) A
  Union All
  Select * From (
  select top 2 id,adddate,title,url from bArticle where ClassId='2' order by adddate desc) B
  Union All
  Select * From (
  select top 2 id,adddate,title,url from bArticle where ClassId='3' order by adddate desc) C
  Union All
  Select * From (
  select top 2 id,adddate,title,url from bArticle where ClassId='4' order by adddate desc) D
  
  
  //MySQL(和PHP搭配之最佳组合)版
  Select * From (
  select id,adddate,title,url from bArticle where ClassId='1' order by adddate desc limit 0,2) A
  Union All
  Select * From (
  select id,adddate,title,url from bArticle where ClassId='2' order by adddate desc limit 0,2) B
  Union All
  Select * From (
  select id,adddate,title,url from bArticle where ClassId='3' order by adddate desc limit 0,2) C
  Union All
  Select * From (
  select id,adddate,title,url from bArticle where ClassId='4' order by adddate desc limit 0,2) D

SQL使用union合并查询结果(转载)的更多相关文章

  1. SQL多表合并查询结果

    两表合并查询,并同时展示及分页SELECT a.* FROM ( ( SELECT punycode, `domain`, 'Success' AS state, add_time, AS refun ...

  2. 7-11使用UNION合并查询

    合并查询的语法: SELECT ...FROM  表名一 UNION SELECT ...FROM 表名二 合并查询的特点: 1: 合并表中的列的个数,数据类型数据类型相同或兼容. 2:UNION 默 ...

  3. 使用union合并查询

    语法: select …..from 表1 union select ……from 表2 2. 合并查询的特点 ① 合并的表中的列的个数.数据类型必须相同或向兼容. ② union默认去掉重复值,如果 ...

  4. sql 用union合并合并查询结果

    合并操作与连接相似,因为他们都是将两个表合并起来的另一个表的方法,然而他们的合并方法有本质的区别, 合并是两个表的相加,连接时时两个表的相乘: 01 在合并中两个表原列的数量与数据类型必须相同:在连接 ...

  5. 数据库原理实验指导(三)使用SQL语言进行简单查询【转载csdn】

    --1.查询全体学生的学号和姓名select sno,sname from student --2.查询全体学生的详细记录select * from student --3.查询软件学院的学生姓名,年 ...

  6. 2个或多个datable类似于sql inner join 合并查询

    public static DataTable DatableInnerJoin(DataTable FirstTB, DataTable SecondTB, DataColumn[] FJC, Da ...

  7. Linq连接查询之左连接、右连接、内连接、全连接、交叉连接、Union合并、Concat连接、Intersect相交、Except与非查询

    内连接查询 内连接与SqL中inner join一样,即找出两个序列的交集 Model1Container model = new Model1Container(); //内连接 var query ...

  8. mysql 中合并查询结果union用法 or、in与union all 的查询效率

    mysql 中合并查询结果union用法 or.in与union all 的查询效率 (2016-05-09 11:18:23) 转载▼ 标签: mysql union or in 分类: mysql ...

  9. oracle 基础SQL语句 多表查询 子查询 分页查询 合并查询 分组查询 group by having order by

    select语句学习 . 创建表 create table user(user varchar2(20), id int); . 查看执行某条命令花费的时间 set timing on: . 查看表的 ...

随机推荐

  1. selenium 实现浏览器 前进和后退

    #coding=utf-8from selenium import webdriver driver = webdriver.Chrome()driver.get("https://www. ...

  2. s2sh框架整合具体配置-xml方式

    s2sh整合之xml方式 说明:本文档所採用的框架版本号为:Struts 2.1.8, Sping2.5.5,  Hibernate 3.5.6 1.    须要的jar包: ------------ ...

  3. atitit. 研发管理---如何根据自己的特挑选 产业、行业、职业、岗位与自己发展的关系

    atitit. 研发管理---如何根据自己的特挑选 产业.行业.职业.岗位与自己发展的关系 1. 产业及分类 1 2. 二.行业 2 3. 职业概念- 3 4. 职业划分 3 5. 职业兴趣分类 4 ...

  4. 基于Vivado的嵌入式开发 ——PS+PL实践

    基于Vivado的嵌入式开发 ——PS走起 硬件平台:ZedBoard 开发工具:Vivado 2014.2 1.规划 废话不多说,依然是流水灯,这次是采用PS+PL实现. 功能依旧简单,目标是为了学 ...

  5. python爬虫请求库之selenium模块

    一 介绍     selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质是通过驱动浏览器,完全模拟浏览器 ...

  6. WP架构设计(一)MVVM回顾

    [MVVM的定义]     MVVM的目的是什么? 简单总结起来一句话:分离UI逻辑和业务逻辑.这一点和被大家熟知的MVP和MVC是一致的.     下面详细来说明下这个问题,下面一段英文来自Msdn ...

  7. 一款基于jQuery外观优雅带遮罩弹出层对话框

    今天我们要来分享一款基于jQuery的弹出层对话框插件,该插件包含多种对话框类型,比如提示框.确认框等.更为实用的是,这款jQuery对话框中的按钮事件也可以被我们所捕获,从而相应对话框按钮的各种事件 ...

  8. Android——Activity和Intent及Activity的生命周期

    实验Activity的生命周期 package com.example.chenshuai.test; import android.app.Activity; import android.os.B ...

  9. setTranslatesAutoresizingMaskIntoConstraints和setFrame组合使用导致的异常

    在用Ojbect-c开发OSX应用的时候需要用到自定义控件并用代码进行布局,很自然地就使用了setTranslatesAutoresizingMaskIntoConstraints和setFrame组 ...

  10. before伪类的超有用应用技巧——水平菜单竖线分隔符

    方法一.li前面加before伪类 <!doctype html> <html dir="ltr" lang="zh-CN"> < ...