• MySQL UNION与 UNION ALL语法及用法


    MySQL语法参考站点

    1.UNION语法

    • 作用:UNION用于把来自多个select 语句的结果垂直组合到一个结果集合中。
    • 要求:在多个select 语句中,对应的列应该具有相同的字段属性,且第一个select 语句中被使用的字段名称也被用于结果的字段名称。
    select ... from table
    union [all]
    select ... from table
    ...
    

    1.1 UNION与 UNION ALL的区别

    当使用UNION时,mysql 会对结果集去重,而使用UNION ALL时mysql 会把所有的记录返回,且效率高于UNION。

    2.UNION用法示例

    UNION常用与数据类似的两张或多张表查询,如不同的数据分类表,或者是数据历史表等,下面是用于测试的两张表;

    2.1使用 UNION 查询

    查询两张表中的文章 id 号及标题,并去掉重复记录:

    SELECT aid,title FROM article UNION SELECT bid,title FROM blog
    

    返回查询结果如下:

    2.2.UNION 查询结果说明

    1. 重复记录是指查询中各个字段完全重复的记录,如上例,若 title 一样但 id 号不一样算作不同记录。
    2. 第一个 SELECT 语句中被使用的字段名称也被用于结果的字段名称,如上例的 aid。
    3. 各 SELECT 语句字段名称可以不同,但字段属性必须一致。

    3.使用 UNION ALL 查询

    查询两张表中的文章 id 号及标题,并返回所有记录:

    SELECT aid,title FROM article UNION ALL SELECT bid,title FROM blog
    

    返回查询结果如下:

    显然,使用 UNION ALL 的时候,只是单纯的把各个查询组合到一起而不会去判断数据是否重复。因此,当确定查询结果中不会有重复数据或者不需要去掉重复数据的时候,应当使用 UNION ALL 以提高查询效率。

    4.UNION ORDER BY

    在UNION中使用 ORDER BY 和 LIMIT 是有些需要特别注意的地方,因此单独列出来说明一下。

    下面是用于测试的两张原始数据表:

    4.1UNION 子句中使用 ORDER BY

    子句中使用 ORDER BY,即将 SELECT 子句的结果先排序,然后再把这些子句查询的结果进行集合。

    在子句中使用 ORDER BY,由于优先级问题,需要将整个子句加圆括号(),且必须与 LIMIT 结合使用:

    (SELECT aid,title FROM article ORDER BY aid DESC LIMIT 10) 
    UNION ALL
    (SELECT bid,title FROM blog ORDER BY bid DESC LIMIT 10)
    

    返回查询结果如下:

    4.2UNION 整句中使用 ORDER BY

    如果想使用 ORDER BY 或 LIMIT 来对全部 UNION 结果进行分类或限制,则应对单个 SELECT 语句加圆括号,并把 ORDER BY 或 LIMIT 放到最后一个的后面。

    (SELECT aid,title FROM article) 
    UNION ALL
    (SELECT bid,title FROM blog)
    ORDER BY aid DESC
    -- 整句中使用 ORDER BY,去掉 SELECT 子句中的圆括号虽然结果是一样的,但为了语句清晰,建议不要省略圆括号。
    

    返回查询结果如下:

    4.3 UNION ORDER BY 应用于别名

    如果 SELECT 中使用到了字段别名,则 OEDER BY 必须引用别名:

    (SELECT a AS b FROM table) UNION (SELECT ...) ORDER BY b
    

    5.UNION LIMIT

    在 UNION 中使用 LIMIT 用于限制返回的记录条数,如果对 SELECT 子句做限制,需要对 SELECT 添加圆括号:

    (SELECT aid,title FROM article LIMIT 2) 
    UNION ALL
    (SELECT bid,title FROM blog LIMIT 2)
    

    该 SQL 会返回2个 SELECT 语句的4条记录。

    如果不添加圆括号,则最后一个 LIMIT 2 会作用于整个 UNION 语句而一共返回 2 条记录。

    同 ORDER BY 类似,当需要对整个 UNION 的结果进行 LIMIT 限制时,建议将各个 SELECT 语句用圆括号括起来以使语句更加清晰:

    (SELECT aid,title FROM article) 
    UNION ALL
    (SELECT bid,title FROM blog)
    LIMIT 2
    
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利
  • 相关阅读:
    【贪心+DFS】D. Field expansion
    【贪心+博弈】C. Naming Company
    【dp】E. Selling Souvenirs
    【multimap的应用】D. Array Division
    内存变量边界对齐
    3.8 高级检索方式(二)
    3.7 高级检索方式(一)
    openGL加载obj文件+绘制大脑表层+高亮染色
    3.6 Lucene基本检索+关键词高亮+分页
    3.5 实例讲解Lucene索引的结构设计
  • 原文地址:https://www.cnblogs.com/hhddd-1024/p/14662579.html
Copyright © 2020-2023  润新知