PgSQL——学习笔记12:UNION 操作符 & UNION ALL 操作符

目录

UNION 操作符:合并两个或多个 SELECT 语句的结果

UNION ALL 操作符:可以连接两个有重复行的 SELECT 语句


UNION 操作符:合并两个或多个 SELECT 语句的结果

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

请注意:

  • UNION 内部的每个 SELECT 语句必须拥有相同数量的列
  • 另外,每个 SELECT 语句中的列也必须拥有相似的数据类型
  • 同时,每个 SELECT 语句中的列的顺序必须相同
/*UNIONS 基础语法如下:*/
/*这里的条件语句可以根据您的需要设置任何表达式。*/

SELECT column1 [, column2 ]
FROM table1 [, table2 ]
[WHERE condition]

UNION

SELECT column1 [, column2 ]
FROM table1 [, table2 ]
[WHERE condition]

实例:

mydb=# delete from department where id = 4;
DELETE 1
mydb=# select * from department;
 id |                        dept                        | emp_id
----+----------------------------------------------------+--------
  1 | IT Billing                                         |      1
  2 | Engineering                                        |      2
  3 | Finance                                            |      7
(3 行记录)

mydb=# INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID) VALUES (4,'Engineering',3),(5,'Finance',4),(6,'Engineering',5),(7,'Finance',6);
INSERT 0 4
mydb=# select * from department;
 id |                        dept                        | emp_id
----+----------------------------------------------------+--------
  1 | IT Billing                                         |      1
  2 | Engineering                                        |      2
  3 | Finance                                            |      7
  4 | Engineering                                        |      3
  5 | Finance                                            |      4
  6 | Engineering                                        |      5
  7 | Finance                                            |      6
(7 行记录)

mydb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
mydb-#    ON COMPANY.ID = DEPARTMENT.EMP_ID;
 emp_id | name  |                        dept
--------+-------+----------------------------------------------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 | James | Finance
      3 | Teddy | Engineering
      4 | Mark  | Finance
      5 | David | Engineering
      6 | Kim   | Finance
(7 行记录)

mydb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
mydb-#     ON COMPANY.ID = DEPARTMENT.EMP_ID;
 emp_id | name  |                        dept
--------+-------+----------------------------------------------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 | James | Finance
      3 | Teddy | Engineering
      4 | Mark  | Finance
      5 | David | Engineering
      6 | Kim   | Finance
        | James |
        | Paul  |
        | James |
(10 行记录)

/*在 SELECT 语句中使用 UNION 子句将两张表连接起来,如下所示:*/
mydb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
mydb-#    ON COMPANY.ID = DEPARTMENT.EMP_ID
mydb-#    UNION
mydb-# SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
mydb-#     ON COMPANY.ID = DEPARTMENT.EMP_ID;
 emp_id | name  |                        dept
--------+-------+----------------------------------------------------
      2 | Allen | Engineering
        | Paul  |
      6 | Kim   | Finance
      1 | Paul  | IT Billing
      5 | David | Engineering
      4 | Mark  | Finance
      3 | Teddy | Engineering
        | James |
      7 | James | Finance
(9 行记录)

UNION ALL 操作符:可以连接两个有重复行的 SELECT 语句

UNION ALL 操作符可以连接两个有重复行的 SELECT 语句,

默认地,UNION 操作符选取不同的值。

如果允许重复的值,请使用 UNION ALL。

/*UINON ALL 子句基础语法如下:*/
/*这里的条件语句可以根据您的需要设置任何表达式。*/

SELECT column1 [, column2 ]
FROM table1 [, table2 ]
[WHERE condition]

UNION ALL

SELECT column1 [, column2 ]
FROM table1 [, table2 ]
[WHERE condition]

 实例:

/*把上面提到的两张表用 SELECT 语句结合 UNION ALL 子句连接起来:*/
mydb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
mydb-#    ON COMPANY.ID = DEPARTMENT.EMP_ID
mydb-#    UNION ALL
mydb-# SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
mydb-#     ON COMPANY.ID = DEPARTMENT.EMP_ID;
 emp_id | name  |                        dept
--------+-------+----------------------------------------------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 | James | Finance
      3 | Teddy | Engineering
      4 | Mark  | Finance
      5 | David | Engineering
      6 | Kim   | Finance
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 | James | Finance
      3 | Teddy | Engineering
      4 | Mark  | Finance
      5 | David | Engineering
      6 | Kim   | Finance
        | James |
        | Paul  |
        | James |
(17 行记录)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中的参考链接提供了关于PostgreSQL中的UNION ALL的性能方面的信息。UNION ALL是一种用于合并多个查询结果集的操作符。它将多个查询的结果集按照列和数据类型进行合并,并保留重复的行。 引用的源码片段解释了在PostgreSQL中处理UNION ALL的过程。当遇到简单的子查询时,PostgreSQL会将其扁平化并追加到"append relation"中。这个过程会创建一个包含多个同级索引扫描的Append节点。 引用是一个示例,展示了如何使用UNION ALL将两个表的结果集合并在一起。这个示例使用了INNER JOIN和LEFT OUTER JOIN两种连接方式。 综上所述,UNION ALL是PostgreSQL中用于合并多个查询结果集的操作符。它能够将多个查询的结果按列和数据类型进行合并,并保留重复的行。在处理UNION ALL时,PostgreSQL会将简单的子查询扁平化并追加到"append relation"中。您可以使用UNION ALL来合并多个表的查询结果集。123 #### 引用[.reference_title] - *1* *2* [Postgresql中使用union all数据类型不一致导致的查询性能问题](https://blog.csdn.net/dazuiba008/article/details/128398922)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *3* [PgSQL——学习笔记12UNION 操作符 & UNION ALL 操作符](https://blog.csdn.net/qq_41361442/article/details/124850048)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值