受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

SELECT INTO

SELECT INTO — 根据查询结果定义一个新表

Synopsis

[ WITH [ RECURSIVE ] with_query [, ...] ]
SELECT [ ALL | DISTINCT [ ON ( expression [, ...] ) ] ]
    [ { * | expression [ [ AS ] output_name ] } [, ...] ]
    INTO [ TEMPORARY | TEMP | UNLOGGED ] [ TABLE ] new_table
    [ FROM from_item [, ...] ]
    [ WHERE condition ]
    [ GROUP BY expression [, ...] ]
    [ HAVING condition ]
    [ WINDOW window_name AS ( window_definition ) [, ...] ]
    [ { UNION | INTERSECT | EXCEPT } [ ALL | DISTINCT ] select ]
    [ ORDER BY expression [ ASC | DESC | USING operator ] [ NULLS { FIRST | LAST } ] [, ...] ]
    [ LIMIT { count | ALL } ]
    [ OFFSET start [ ROW | ROWS ] ]
    [ FETCH { FIRST | NEXT } [ count ] { ROW | ROWS } ONLY ]
    [ FOR { UPDATE | SHARE } [ OF table_name [, ...] ] [ NOWAIT ] [...] ]

描述

SELECT INTO创建一个新表,并用查询计算得到的 数据填充该表。与普通的SELECT不同,这些数据不 会返回给客户端。新表的列具有与SELECT输出列对 应的名称和数据类型。

参数

TEMPORARYTEMP #

如果指定,该表将创建为临时表。详见 CREATE TABLE

UNLOGGED #

如果指定,该表将创建为不记录日志表。详见 CREATE TABLE

new_table #

要创建的表的名称(可选地带模式限定)。

所有其他参数都在SELECT中有详细说明。

注解

CREATE TABLE AS在功能上与 SELECT INTO类似。CREATE TABLE AS 是推荐使用的语法,因为这种形式的SELECT INTOECPGPL/pgSQL中不可用,因为它们对 INTO子句有不同的解释。此外, CREATE TABLE AS提供的功能是 SELECT INTO所提供功能的超集。

CREATE TABLE AS不同,SELECT INTO不允许使用USING method 指定诸如表访问方法之类的属性,也不允许使用TABLESPACE tablespace_name指定表空间。如有需要,请使用 CREATE TABLE AS。因此,新表会选用默认的表访问方 法。更多信息请参见default_table_access_method

示例

创建一个新表films_recent,它只包含表 films中的最近条目:

SELECT * INTO films_recent FROM films WHERE date_prod >= '2002-01-01';

兼容性

SQL 标准使用SELECT INTO表示将值选入宿主程序 的标量变量,而不是创建一个新表。这确实是 ECPG(见Chapter 34)和 PL/pgSQL(见Chapter 41) 中的用法。PostgreSQL使用SELECT INTO表示创建表则是历史遗留用法。其他一些 SQL 实现也以这种 方式使用SELECT INTO(但大多数 SQL 实现改为支 持CREATE TABLE AS)。撇开这类兼容性考虑,对 于新代码,最好为此目的使用CREATE TABLE AS

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。