SELECT INTO — 根据查询结果定义一个新表
[ WITH [ RECURSIVE ]with_query[, ...] ] SELECT [ ALL | DISTINCT [ ON (expression[, ...] ) ] ] [ { * |expression[ [ AS ]output_name] } [, ...] ] INTO [ TEMPORARY | TEMP | UNLOGGED ] [ TABLE ]new_table[ FROMfrom_item[, ...] ] [ WHEREcondition] [ GROUP BYexpression[, ...] ] [ HAVINGcondition] [ WINDOWwindow_nameAS (window_definition) [, ...] ] [ { UNION | INTERSECT | EXCEPT } [ ALL | DISTINCT ]select] [ ORDER BYexpression[ ASC | DESC | USINGoperator] [ NULLS { FIRST | LAST } ] [, ...] ] [ LIMIT {count| ALL } ] [ OFFSETstart[ ROW | ROWS ] ] [ FETCH { FIRST | NEXT } [count] { ROW | ROWS } ONLY ] [ FOR { UPDATE | SHARE } [ OFtable_name[, ...] ] [ NOWAIT ] [...] ]
SELECT INTO创建一个新表,并用查询计算得到的 数据填充该表。与普通的SELECT不同,这些数据不 会返回给客户端。新表的列具有与SELECT输出列对 应的名称和数据类型。
TEMPORARY 或 TEMP #如果指定,该表将创建为临时表。详见 CREATE TABLE。
UNLOGGED #如果指定,该表将创建为不记录日志表。详见 CREATE TABLE。
new_table #要创建的表的名称(可选地带模式限定)。
所有其他参数都在SELECT中有详细说明。
CREATE TABLE AS在功能上与 SELECT INTO类似。CREATE TABLE AS 是推荐使用的语法,因为这种形式的SELECT INTO在ECPG 或PL/pgSQL中不可用,因为它们对 INTO子句有不同的解释。此外, CREATE TABLE AS提供的功能是 SELECT INTO所提供功能的超集。
与CREATE TABLE AS不同,SELECT INTO不允许使用USING 指定诸如表访问方法之类的属性,也不允许使用methodTABLESPACE 指定表空间。如有需要,请使用 tablespace_nameCREATE 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。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。