PostgreSQL 教程: UNION 组合多个查询的结果集

八月 30, 2023

摘要:在本教程中,您将学习如何使用 PostgreSQL 的 UNION 运算符,将多个查询的结果集合并为单个结果集。

PostgreSQL UNION 运算符简介

UNION运算符将两个或多个SELECT语句的结果集组合成一个结果集。

下面说明了组合两个查询的结果集的UNION运算符的语法:

SELECT select_list_1
FROM table_expresssion_1
UNION
SELECT select_list_2
FROM table_expression_2

要使用UNION运算符组合两个查询的结果集,查询必须符合以下规则:

  • 两个查询的选择列表中列的数量和顺序必须相同。
  • 数据类型必须兼容。

UNION运算符从组合数据集中删除所有重复行。要保留重复的行,请改用UNION ALL

下面的维恩图说明了UNION工作原理:

img

带有 ORDER BY 子句的 UNION

UNION运算符可以将第一个查询的结果集中的行放置在第二个查询的结果集中的行之前、之后或之间。

要对最终结果集中的行进行排序,请在第二个查询中使用ORDER BY子句。

在实践中,您可能会使用UNION运算符来组合来自数据仓库或商业智能系统中未完全规范化的相似表的数据。

设置样例表

以下语句创建两个表:top_rated_filmsmost_popular_films,并向这些表中插入数据:

DROP TABLE IF EXISTS top_rated_films;
CREATE TABLE top_rated_films(
	title VARCHAR NOT NULL,
	release_year SMALLINT
);

DROP TABLE IF EXISTS most_popular_films;
CREATE TABLE most_popular_films(
	title VARCHAR NOT NULL,
	release_year SMALLINT
);

INSERT INTO 
   top_rated_films(title,release_year)
VALUES
   ('The Shawshank Redemption',1994),
   ('The Godfather',1972),
   ('12 Angry Men',1957);

INSERT INTO 
   most_popular_films(title,release_year)
VALUES
   ('An American Pickle',2020),
   ('The Godfather',1972),
   ('Greyhound',2020);

top_rated_films表中数据如下所示:

SELECT * FROM top_rated_films;

img

以下语句返回most_popular_films表中的数据:

SELECT * FROM most_popular_films;

img

PostgreSQL UNION 示例

让我们看一些使用 PostgreSQL 的UNION运算符的示例。

1) 简单的 PostgreSQL UNION 示例

以下语句使用UNION运算符组合两个表中的数据:

SELECT * FROM top_rated_films
UNION
SELECT * FROM most_popular_films;

查询返回以下结果:

PostgreSQL UNION example

由于UNION运算符删除了 1 个重复行,因此结果集中包含 5 行。

2) PostgreSQL UNION ALL 示例

以下语句使用UNION ALL运算符组合top_rated_filmsmost_popular_films表中的结果集:

SELECT * FROM top_rated_films
UNION ALL
SELECT * FROM most_popular_films;

PostgreSQL UNION ALL example

在此示例中,重复行保留在结果集中。

3) 带 ORDER BY 子句 UNION ALL 示例

要对UNION运算符返回的结果进行排序,请将ORDER BY子句放在最后一个查询的末尾,如下所示:

SELECT * FROM top_rated_films
UNION ALL
SELECT * FROM most_popular_films
ORDER BY title;

PostgreSQL UNION with ORDER BY example

如果将ORDER BY子句放置在每个查询的末尾,则组合结果集将不会按您预期的方式排序。

因为当UNION运算符合并每个查询的排序结果集时,它不能保证最终结果集中行的顺序。

在本教程中,您学习了如何使用 PostgreSQL 的UNION以及UNION ALL,将多个查询的结果集合并为一个结果集。