2003-01-19 01:13:31 +01:00
|
|
|
<!-- $Header: /cvsroot/pgsql/doc/src/sgml/ref/set_transaction.sgml,v 1.12 2003/01/19 00:13:31 momjian Exp $ -->
|
2000-06-18 23:24:54 +02:00
|
|
|
<refentry id="SQL-SET-TRANSACTION">
|
2000-11-24 21:16:40 +01:00
|
|
|
<docinfo>
|
|
|
|
<date>2000-11-24</date>
|
|
|
|
</docinfo>
|
|
|
|
|
2000-06-18 23:24:54 +02:00
|
|
|
<refmeta>
|
2000-07-14 17:27:14 +02:00
|
|
|
<refentrytitle id="SQL-SET-TRANSACTION-TITLE">SET TRANSACTION</refentrytitle>
|
2000-06-18 23:24:54 +02:00
|
|
|
<refmiscinfo>SQL - Language Statements</refmiscinfo>
|
|
|
|
</refmeta>
|
2000-11-24 21:16:40 +01:00
|
|
|
|
2000-06-18 23:24:54 +02:00
|
|
|
<refnamediv>
|
|
|
|
<refname>SET TRANSACTION</refname>
|
2001-09-03 14:57:50 +02:00
|
|
|
<refpurpose>set the characteristics of the current transaction</refpurpose>
|
2000-06-18 23:24:54 +02:00
|
|
|
</refnamediv>
|
2000-11-24 21:16:40 +01:00
|
|
|
|
2000-06-18 23:24:54 +02:00
|
|
|
<refsynopsisdiv>
|
|
|
|
<synopsis>
|
2003-01-10 23:03:30 +01:00
|
|
|
SET TRANSACTION
|
|
|
|
[ ISOLATION LEVEL { READ COMMITTED | SERIALIZABLE } ] [ READ WRITE | READ ONLY ]
|
|
|
|
SET SESSION CHARACTERISTICS AS TRANSACTION
|
|
|
|
[ ISOLATION LEVEL { READ COMMITTED | SERIALIZABLE } ] [ READ WRITE | READ ONLY ]
|
2000-06-18 23:24:54 +02:00
|
|
|
</synopsis>
|
|
|
|
</refsynopsisdiv>
|
|
|
|
|
|
|
|
<refsect1>
|
|
|
|
<title>Description</title>
|
|
|
|
|
|
|
|
<para>
|
2003-01-10 23:03:30 +01:00
|
|
|
The <command>SET TRANSACTION</command> command sets the transaction
|
|
|
|
characteristics of the current SQL-transaction. It has no effect on
|
|
|
|
any subsequent transactions. <command>SET SESSION
|
|
|
|
CHARACTERISTICS</command> sets the default transaction
|
|
|
|
characteristics for each transaction of a session. <command>SET
|
|
|
|
TRANSACTION</command> can override it for an individual
|
|
|
|
transaction.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The available transaction characteristics are the transaction
|
|
|
|
isolation level and the transaction access mode (read/write or
|
|
|
|
read-only).
|
2000-06-18 23:24:54 +02:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The isolation level of a transaction determines what data the
|
|
|
|
transaction can see when other transactions are running concurrently.
|
|
|
|
|
|
|
|
<variablelist>
|
|
|
|
<varlistentry>
|
2003-01-11 01:00:03 +01:00
|
|
|
<term><literal>READ COMMITTED</literal></term>
|
2000-06-18 23:24:54 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
A statement can only see rows committed before it began. This
|
|
|
|
is the default.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</varlistentry>
|
|
|
|
|
|
|
|
<varlistentry>
|
2003-01-10 23:03:30 +01:00
|
|
|
<term><literal>SERIALIZABLE</literal></term>
|
2000-06-18 23:24:54 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
The current transaction can only see rows committed before
|
2002-01-20 23:19:57 +01:00
|
|
|
first query or data-modification statement was executed in this transaction.
|
2000-06-18 23:24:54 +02:00
|
|
|
</para>
|
|
|
|
<tip>
|
|
|
|
<para>
|
|
|
|
Intuitively, serializable means that two concurrent
|
|
|
|
transactions will leave the database in the same state as if
|
|
|
|
the two has been executed strictly after one another in either
|
|
|
|
order.
|
|
|
|
</para>
|
|
|
|
</tip>
|
|
|
|
</listitem>
|
|
|
|
</varlistentry>
|
|
|
|
</variablelist>
|
2003-01-10 23:03:30 +01:00
|
|
|
|
|
|
|
The transaction isolation level cannot be set after the first query
|
|
|
|
or data-modification statement (<command>SELECT</command>,
|
|
|
|
<command>INSERT</command>, <command>DELETE</command>,
|
|
|
|
<command>UPDATE</command>, <command>FETCH</command>,
|
|
|
|
<command>COPY</command>) of a transaction has been executed.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The transaction access mode determines whether the transaction is
|
|
|
|
read/write or read-only. Read/write is the default. When a
|
|
|
|
transaction is read-only, the following SQL commands are
|
|
|
|
disallowed: <literal>INSERT</literal>, <literal>UPDATE</literal>,
|
|
|
|
<literal>DELETE</literal>, and <literal>COPY TO</literal> if the
|
|
|
|
table they would write to is not a temporary table; all
|
|
|
|
<literal>CREATE</literal>, <literal>ALTER</literal>, and
|
|
|
|
<literal>DROP</literal> commands; <literal>COMMENT</literal>,
|
|
|
|
<literal>GRANT</literal>, <literal>REVOKE</literal>,
|
|
|
|
<literal>TRUNCATE</literal>; and <literal>EXPLAIN ANALYZE</literal>
|
|
|
|
and <literal>EXECUTE</literal> if the command they would execute is
|
|
|
|
among those listed. This is a high-level notion of read-only that
|
|
|
|
does not prevent writes to disk.
|
2000-06-18 23:24:54 +02:00
|
|
|
</para>
|
|
|
|
</refsect1>
|
|
|
|
|
2001-07-01 00:03:26 +02:00
|
|
|
<refsect1>
|
|
|
|
<title>Notes</title>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The session default transaction isolation level can also be set
|
2001-10-09 20:46:00 +02:00
|
|
|
with the command
|
|
|
|
<programlisting>
|
|
|
|
SET default_transaction_isolation = '<replaceable>value</replaceable>'
|
|
|
|
</programlisting>
|
2003-01-19 01:13:31 +01:00
|
|
|
and in the configuration file. Consult the &cite-admin; for more
|
|
|
|
information.
|
2001-07-01 00:03:26 +02:00
|
|
|
</para>
|
|
|
|
</refsect1>
|
|
|
|
|
2000-07-14 17:27:14 +02:00
|
|
|
<refsect1 id="R1-SQL-SET-TRANSACTION-3">
|
2000-06-18 23:24:54 +02:00
|
|
|
<title>Compatibility</title>
|
|
|
|
|
2000-07-14 17:27:14 +02:00
|
|
|
<refsect2 id="R2-SQL-SET-TRANSACTION-4">
|
|
|
|
<title>SQL92, SQL99</title>
|
2000-06-18 23:24:54 +02:00
|
|
|
|
2000-07-14 17:27:14 +02:00
|
|
|
<para>
|
2003-01-10 23:03:30 +01:00
|
|
|
<option>SERIALIZABLE</option> is the default transaction isolation level in
|
2002-08-04 06:31:44 +02:00
|
|
|
<acronym>SQL</acronym>. <productname>PostgreSQL</productname> does
|
|
|
|
not provide the isolation levels <option>READ UNCOMMITTED</option>
|
|
|
|
and <option>REPEATABLE READ</option>. Because of multiversion
|
|
|
|
concurrency control, the <option>SERIALIZABLE</option> level is not
|
2003-01-19 01:13:31 +01:00
|
|
|
truly serializable. See the &cite-user; for details.
|
2000-07-14 17:27:14 +02:00
|
|
|
</para>
|
2000-06-18 23:24:54 +02:00
|
|
|
|
2000-07-14 17:27:14 +02:00
|
|
|
<para>
|
2003-01-10 23:03:30 +01:00
|
|
|
In <acronym>SQL</acronym> there is one other transaction
|
|
|
|
characteristic that can be set with these commands: the size of
|
|
|
|
the diagnostics area. This concept is not supported in
|
|
|
|
<productname>PostgreSQL</productname>.
|
2000-07-14 17:27:14 +02:00
|
|
|
</para>
|
|
|
|
</refsect2>
|
2000-06-18 23:24:54 +02:00
|
|
|
</refsect1>
|
|
|
|
</refentry>
|
|
|
|
|
2000-07-14 17:27:14 +02:00
|
|
|
<!-- 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:
|
|
|
|
-->
|