mirror of
https://github.com/postgres/postgres.git
synced 2025-09-03 15:22:11 +03:00
250 lines
6.3 KiB
Plaintext
250 lines
6.3 KiB
Plaintext
<!--
|
|
$Header: /cvsroot/pgsql/doc/src/sgml/ref/insert.sgml,v 1.16 2001/12/08 03:24:37 thomas Exp $
|
|
PostgreSQL documentation
|
|
-->
|
|
|
|
<refentry id="SQL-INSERT">
|
|
<refmeta>
|
|
<refentrytitle id="SQL-INSERT-TITLE">INSERT</refentrytitle>
|
|
<refmiscinfo>SQL - Language Statements</refmiscinfo>
|
|
</refmeta>
|
|
<refnamediv>
|
|
<refname>
|
|
INSERT
|
|
</refname>
|
|
<refpurpose>
|
|
create new rows in a table
|
|
</refpurpose>
|
|
</refnamediv>
|
|
<refsynopsisdiv>
|
|
<refsynopsisdivinfo>
|
|
<date>2000-08-08</date>
|
|
</refsynopsisdivinfo>
|
|
<synopsis>
|
|
INSERT INTO <replaceable class="PARAMETER">table</replaceable> [ ( <replaceable class="PARAMETER">column</replaceable> [, ...] ) ]
|
|
{ DEFAULT VALUES | VALUES ( <replaceable class="PARAMETER">expression</replaceable> [, ...] ) | SELECT <replaceable class="PARAMETER">query</replaceable> }
|
|
</synopsis>
|
|
|
|
<refsect2 id="R2-SQL-INSERT-1">
|
|
<title>
|
|
Inputs
|
|
</title>
|
|
|
|
<para>
|
|
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><replaceable class="PARAMETER">table</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
The name of an existing table.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><replaceable class="PARAMETER">column</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
The name of a column in <replaceable class="PARAMETER">table</replaceable>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term>DEFAULT VALUES</term>
|
|
<listitem>
|
|
<para>
|
|
All columns will be filled by NULLs or by values specified
|
|
when the table was created using DEFAULT clauses.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><replaceable class="PARAMETER">expression</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
A valid expression or value to assign to <replaceable
|
|
class="PARAMETER">column</replaceable>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><replaceable class="PARAMETER">query</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
A valid query. Refer to the SELECT statement for a further description
|
|
of valid arguments.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2 id="R2-SQL-INSERT-2">
|
|
<title>
|
|
Outputs
|
|
</title>
|
|
<para>
|
|
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><computeroutput>
|
|
INSERT <replaceable>oid</replaceable> 1
|
|
</computeroutput></term>
|
|
<listitem>
|
|
<para>
|
|
Message returned if only one row was inserted.
|
|
<returnvalue><replaceable>oid</replaceable></returnvalue>
|
|
is the numeric <acronym>OID</acronym> of the inserted row.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><computeroutput>
|
|
INSERT 0 <replaceable>#</replaceable>
|
|
</computeroutput></term>
|
|
<listitem>
|
|
<para>
|
|
Message returned if more than one rows were inserted.
|
|
<returnvalue><replaceable>#</replaceable></returnvalue>
|
|
is the number of rows inserted.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</para>
|
|
</refsect2>
|
|
</refsynopsisdiv>
|
|
|
|
<refsect1 id="R1-SQL-INSERT-1">
|
|
<title>
|
|
Description
|
|
</title>
|
|
|
|
<para>
|
|
<command>INSERT</command> allows one to insert new rows into a
|
|
table. One can insert
|
|
a single row at a time or several rows as a result of a query.
|
|
The columns in the target list may be listed in any order.
|
|
</para>
|
|
|
|
<para>
|
|
Each column not present in the target list will be inserted
|
|
using a default value, either a declared DEFAULT value
|
|
or NULL. <productname>PostgreSQL</productname> will reject the new
|
|
column if a NULL is inserted into a column declared NOT NULL.
|
|
</para>
|
|
|
|
<para>
|
|
If the expression for each column
|
|
is not of the correct data type, automatic type coercion will be
|
|
attempted.
|
|
</para>
|
|
|
|
<para>
|
|
You must have insert privilege to a table in order to append
|
|
to it, as well as select privilege on any table specified
|
|
in a WHERE clause.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1 id="R1-SQL-INSERT-2">
|
|
<title>
|
|
Usage
|
|
</title>
|
|
<para>
|
|
Insert a single row into table <literal>films</literal>:
|
|
|
|
<programlisting>
|
|
INSERT INTO films VALUES
|
|
('UA502','Bananas',105,'1971-07-13','Comedy',INTERVAL '82 minute');
|
|
</programlisting>
|
|
</para>
|
|
|
|
<para>
|
|
In this second example the last column <literal>len</literal> is
|
|
omitted and therefore it will have the default value of NULL:
|
|
|
|
<programlisting>
|
|
INSERT INTO films (code, title, did, date_prod, kind)
|
|
VALUES ('T_601', 'Yojimbo', 106, DATE '1961-06-16', 'Drama');
|
|
</programlisting>
|
|
</para>
|
|
|
|
<para>
|
|
Insert a single row into table distributors; note that
|
|
only column <literal>name</literal> is specified, so the omitted
|
|
column <literal>did</literal> will be assigned its default value:
|
|
|
|
<programlisting>
|
|
INSERT INTO distributors (name) VALUES ('British Lion');
|
|
</programlisting>
|
|
</para>
|
|
|
|
<para>
|
|
Insert several rows into table films from table <literal>tmp</literal>:
|
|
|
|
<programlisting>
|
|
INSERT INTO films SELECT * FROM tmp;
|
|
</programlisting>
|
|
</para>
|
|
|
|
<para>
|
|
Insert into arrays (refer to the
|
|
<citetitle>PostgreSQL User's Guide</citetitle> for further
|
|
information about arrays):
|
|
|
|
<programlisting>
|
|
-- Create an empty 3x3 gameboard for noughts-and-crosses
|
|
-- (all of these queries create the same board attribute)
|
|
INSERT INTO tictactoe (game, board[1:3][1:3])
|
|
VALUES (1,'{{"","",""},{},{"",""}}');
|
|
INSERT INTO tictactoe (game, board[3][3])
|
|
VALUES (2,'{}');
|
|
INSERT INTO tictactoe (game, board)
|
|
VALUES (3,'{{,,},{,,},{,,}}');
|
|
</programlisting>
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1 id="R1-SQL-INSERT-3">
|
|
<title>
|
|
Compatibility
|
|
</title>
|
|
|
|
<refsect2 id="R2-SQL-INSERT-4">
|
|
<title>
|
|
SQL92
|
|
</title>
|
|
<para>
|
|
<command>INSERT</command> is fully compatible with <acronym>SQL92</acronym>.
|
|
Possible limitations in features of the
|
|
<replaceable class="PARAMETER">query</replaceable>
|
|
clause are documented for
|
|
<xref linkend="sql-select" endterm="sql-select-title">.
|
|
</para>
|
|
</refsect2>
|
|
</refsect1>
|
|
</refentry>
|
|
|
|
<!-- Keep this comment at the end of the file
|
|
Local variables:
|
|
mode: sgml
|
|
sgml-omittag:nil
|
|
sgml-shorttag:t
|
|
sgml-minimize-attributes:nil
|
|
sgml-always-quote-attributes:t
|
|
sgml-indent-step:1
|
|
sgml-indent-data:t
|
|
sgml-parent-document:nil
|
|
sgml-default-dtd-file:"../reference.ced"
|
|
sgml-exposed-tags:nil
|
|
sgml-local-catalogs:"/usr/lib/sgml/catalog"
|
|
sgml-local-ecat-files:nil
|
|
End:
|
|
-->
|