More about chained mode and isolation.
This commit is contained in:
parent
962c66d83f
commit
4ca7b4d2e5
@ -1,20 +1,44 @@
|
|||||||
.\" This is -*-nroff-*-
|
.\" This is -*-nroff-*-
|
||||||
.\" XXX standard disclaimer belongs here....
|
.\" XXX standard disclaimer belongs here....
|
||||||
.\" $Header: /cvsroot/pgsql/src/man/Attic/begin.l,v 1.5 1998/03/25 01:54:48 momjian Exp $
|
.\" $Header: /cvsroot/pgsql/src/man/Attic/begin.l,v 1.6 1999/06/11 05:40:18 vadim Exp $
|
||||||
.TH BEGIN SQL 11/05/95 PostgreSQL PostgreSQL
|
.TH BEGIN SQL 11/05/95 PostgreSQL PostgreSQL
|
||||||
.SH NAME
|
.SH NAME
|
||||||
begin - begins a transaction
|
begin - begins a transaction in chained mode
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.nf
|
.nf
|
||||||
\fBbegin\fP \fB[transaction|work]\fR
|
\fBbegin\fP \fB[transaction|work]\fR
|
||||||
.fi
|
.fi
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This command begins a user transaction which Postgres will guarantee is
|
|
||||||
serializable with respect to all concurrently executing transactions.
|
By default, Postgres executes transactions in unchained mode (also known as
|
||||||
Postgres uses two-phase locking to perform this task. If the transaction
|
autocommit feature in other DBMSes). In other words, each user statement is
|
||||||
is committed, Postgres will ensure that all updates are done or none of
|
executed in its own transaction and commit is implicit (if execution was
|
||||||
them are done. Transactions have the standard ACID (atomic,
|
successfull). BEGIN initiates a user transaction in chained mode, i.e. all
|
||||||
consistent, isolatable, and durable) property.
|
user statements after BEGIN command will be executed in single transaction
|
||||||
|
untill explicit COMMIT, ROLLBACK or execution abort. Statements in chained
|
||||||
|
mode are executed much faster, because of transaction start/commit requires
|
||||||
|
significant CPU and disk activity. This mode is also required for
|
||||||
|
consistency when changing one of related tables.
|
||||||
|
|
||||||
|
Default transaction isolation level in Postgres is READ COMMITTED one, when
|
||||||
|
queries inside transaction see only changes committed before query
|
||||||
|
execution. So, you have to use SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
|
||||||
|
command just after BEGIN if you need in better transaction isolation. In
|
||||||
|
SERIALIZABLE mode queries will see only changes committed before entire
|
||||||
|
transaction began (actually, before execution of first DML statement in
|
||||||
|
serializable transaction).
|
||||||
|
|
||||||
|
If the transaction is committed, Postgres will ensure either that all
|
||||||
|
updates are done or else that none of them are done. Transactions have the
|
||||||
|
standard ACID (atomic, consistent, isolatable, and durable) property.
|
||||||
|
|
||||||
|
\fBNote\fR: There is no explicit BEGIN command in SQL92; transaction
|
||||||
|
initiation is always implicit and it terminates either with a COMMIT or with
|
||||||
|
a ROLLBACK statement (i.e. all transactions are chained). SQL92 also
|
||||||
|
requires SERIALIZABLE to be default transaction isolation level.
|
||||||
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
rollback(l),
|
rollback(l),
|
||||||
commit(l).
|
commit(l),
|
||||||
|
set(l),
|
||||||
|
lock(l).
|
||||||
|
Loading…
x
Reference in New Issue
Block a user