zoukankan      html  css  js  c++  java
  • UNION 和 UNION ALL 操作符

    UNION 操作符

    UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

    注意:

    1.UNION 内部的 SELECT 语句必须拥有同样数量的列

    2.列也必须拥有相似的数据类型

    3.每条 SELECT 语句中的列的顺序必须同样

    UNION 语法

    SELECT column_name(s) FROM table_name1
    UNION
    SELECT column_name(s) FROM table_name2
    

    凝视:默认地,UNION 操作符选取不同的值。假设同意反复的值,请使用 UNION ALL。

    UNION ALL 语法

    SELECT column_name(s) FROM table_name1
    UNION ALL
    SELECT column_name(s) FROM table_name2
    

    另外,UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。

    以下的样例中使用的原始表:

    Employees_China:

    E_ID E_Name
    01 Zhang, Hua
    02 Wang, Wei
    03 Carter, Thomas
    04 Yang, Ming

    Employees_USA:

    E_ID E_Name
    01 Adams, John
    02 Bush, George
    03 Carter, Thomas
    04 Gates, Bill

    使用 UNION 命令

    实例

    列出全部在中国和美国的不同的雇员名:

    SELECT E_Name FROM Employees_China
    UNION
    SELECT E_Name FROM Employees_USA
    

    结果

    E_Name
    Zhang, Hua
    Wang, Wei
    Carter, Thomas
    Yang, Ming
    Adams, John
    Bush, George
    Gates, Bill

    凝视:这个命令无法列出在中国和美国的全部雇员。在上面的样例中。我们有两个名字同样的雇员,他们其中仅仅有一个人被列出来了。

    UNION 命令仅仅会选取不同的值。

    使用 UNION ALL 命令

    UNION ALL 命令和 UNION 命令差点儿是等效的,只是 UNION ALL 命令会列出全部的值。

    实例:

    列出在中国和美国的全部的雇员:

    SELECT E_Name FROM Employees_China
    UNION ALL
    SELECT E_Name FROM Employees_USA
    

    结果

    E_Name
    Zhang, Hua
    Wang, Wei
    Carter, Thomas
    Yang, Ming
    Adams, John
    Bush, George
    Carter, Thomas
    Gates, Bill
  • 相关阅读:
    luogu P3238 [HNOI2014]道路堵塞
    luogu P3235 [HNOI2014]江南乐
    luogu P3237 [HNOI2014]米特运输
    luogu P3233 [HNOI2014]世界树
    luogu P3234 [HNOI2014]抄卡组
    luogu P3250 [HNOI2016]网络
    luogu P3201 [HNOI2009]梦幻布丁
    luogu P4148 简单题
    luogu P3767 膜法
    luogu P4314 CPU监控
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/6790435.html
Copyright © 2011-2022 走看看