PgSQL - 研究ノート 12: UNION 演算子と UNION ALL 演算子

目次

UNION 演算子: 2 つ以上の SELECT ステートメントの結果を結合します。

UNION ALL 演算子: 重複した行を持つ 2 つの SELECT ステートメントを接続できます。


UNION 演算子: 2 つ以上の SELECT ステートメントの結果を結合します。

UNION 演算子は、2 つ以上の 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 演算子: 重複した行を持つ 2 つの SELECT ステートメントを接続できます。

UNION ALL 演算子は、重複した行を持つ 2 つの 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 行记录)

おすすめ

転載: blog.csdn.net/qq_41361442/article/details/124850048