zoukankan      html  css  js  c++  java
  • MySQL学习-- UNION与UNION ALL

    UNION用于把来自许多SELECT语句的结果组合到一个结果集合中,也叫联合查询。

    1
    2
    3
    4
    5
    SELECT ...
    UNION [ALL | DISTINCT]
    SELECT ...
    [UNION [ALL | DISTINCT]
    SELECT ...]

    在多个 SELECT 语句中,第一个 SELECT 语句中被使用的字段名称将被用于结果的字段名称。

    当使用 UNION 时,MySQL 会把结果集中重复的记录删掉,而使用 UNION ALL ,MySQL 会把所有的记录返回,且效率高于 UNION。

    数据准备

    student表

    teacher表

    查询数据如下

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    mysql> SELECT * FROM student;
    +----+------+-----+---------+
    | id | name | age | classId |
    +----+------+-----+---------+
    |  1 | s1   |  20 |       1 |
    |  2 | s2   |  22 |       1 |
    |  3 | s3   |  22 |       2 |
    |  4 | s4   |  25 |       2 |
    +----+------+-----+---------+
    4 rows in set
     
    mysql> SELECT * FROM teacher;
    +----+------+-----+
    | id | name | age |
    +----+------+-----+
    |  1 | t1   |  36 |
    |  2 | t2   |  33 |
    |  3 | s3   |  22 |
    +----+------+-----+
    3 rows in set

    使用 UNION的结果

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    mysql> SELECT id, name, age FROM student
        -> UNION  -- 与UNION DISTINCT相同
        -> SELECT id, name, age FROM teacher;
    +----+------+-----+
    | id | name | age |
    +----+------+-----+
    |  1 | s1   |  20 |
    |  2 | s2   |  22 |
    |  3 | s3   |  22 |
    |  4 | s4   |  25 |
    |  1 | t1   |  36 |
    |  2 | t2   |  33 |
    +----+------+-----+
    6 rows in set

    使用 UNION ALL的结果

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    mysql> SELECT id, name, age FROM student
        -> UNION ALL
        -> SELECT id, name, age FROM teacher;
    +----+------+-----+
    | id | name | age |
    +----+------+-----+
    |  1 | s1   |  20 |
    |  2 | s2   |  22 |
    |  3 | s3   |  22 |
    |  4 | s4   |  25 |
    |  1 | t1   |  36 |
    |  2 | t2   |  33 |
    |  3 | s3   |  22 |
    +----+------+-----+
    7 rows in set

    其实联合查询跟字段的类型无关,只要求每个SELECT查询的字段数一样,能对应即可,如

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    mysql> SELECT id, name, age FROM student -- 这里可以看出第一个SELECT语句中的字段名称被用作最后结果的字段名
        -> UNION
        -> SELECT age, name, id FROM teacher;
    +----+------+-----+
    | id | name | age |
    +----+------+-----+
    |  1 | s1   |  20 |
    |  2 | s2   |  22 |
    |  3 | s3   |  22 |
    |  4 | s4   |  25 |
    | 36 | t1   |   1 |
    | 33 | t2   |   2 |
    | 22 | s3   |   3 |
    +----+------+-----+
    7 rows in set

    在联合查询中,当使用ORDER BY的时候,需要对SELECT语句添加括号,并且与LIMIT结合使用才生效,如

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    mysql> (SELECT classId, id, name, age FROM student WHERE classId = 1 ORDER BY age DESC)
        -> UNION
        -> (SELECT classId, id, name, age FROM student WHERE classId = 2 ORDER BY age);
    +---------+----+------+-----+
    | classId | id | name | age |
    +---------+----+------+-----+
    |       1 |  1 | s1   |  20 |
    |       1 |  2 | s2   |  22 |
    |       2 |  3 | s3   |  22 |
    |       2 |  4 | s4   |  25 |
    +---------+----+------+-----+
    4 rows in set

    此时classId为1的学生并没有按照年龄进行降序,结合LIMIT后

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    mysql> (SELECT classId, id, name, age FROM student WHERE classId = 1 ORDER BY age DESC LIMIT 2)
        -> UNION
        -> (SELECT classId, id, name, age FROM student WHERE classId = 2 ORDER BY age);
    +---------+----+------+-----+
    | classId | id | name | age |
    +---------+----+------+-----+
    |       1 |  2 | s2   |  22 |
    |       1 |  1 | s1   |  20 |
    |       2 |  3 | s3   |  22 |
    |       2 |  4 | s4   |  25 |
    +---------+----+------+-----+
    4 rows in set
  • 相关阅读:
    mysql 查询缓存
    DevExpress 使用示例
    搜索营销推广学习资料
    mysql 导出表结构
    Google nexus one 获取root权限
    ASP.NET 使用Get方式请求WebService,并得到DataSet结果
    Iweboffice 2009 Winform版 Word文件的打开与保存
    【转】mysql 分析查找执行效率慢的SQL语句
    java.sql.BatchUpdateException: Lock wait timeout exceeded; try restarting transaction
    java 中job的core配置
  • 原文地址:https://www.cnblogs.com/jpfss/p/11244684.html
Copyright © 2011-2022 走看看