START TRANSACTION
START TRANSACTION — начать блок транзакции
Синтаксис
START TRANSACTION [режим_транзакции
[, ...] ] Гдережим_транзакции
может быть следующим: ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED } READ WRITE | READ ONLY [ NOT ] DEFERRABLE
Описание
Эта команда начинает новый блок транзакции. Если указан уровень изоляции, режим чтения/записи или допустимость откладывания транзакции, новая транзакция получит эти характеристики, как при выполнении команды SET TRANSACTION. Данная команда равнозначна команде BEGIN.
Параметры
За описанием параметров этого оператора обратитесь к SET TRANSACTION.
Совместимость
Согласно стандарту, выполнять START TRANSACTION
, чтобы начать блок транзакции, необязательно: блок неявно начинает любая команда SQL. Поведение Postgres Pro можно представить как неявное выполнение COMMIT
после каждой команды, которой не предшествует START TRANSACTION
(или BEGIN
), и поэтому такое поведение часто называется «автофиксацией». Другие реляционные СУБД тоже могут предлагать автофиксацию как удобную возможность.
Значение DEFERRABLE
параметра режим_транзакции
является языковым расширением Postgres Pro.
Стандарт SQL требует, чтобы последовательные режимы_транзакций
разделялись запятыми, но по историческим причинам Postgres Pro позволяет опустить запятые.
См. также сведения о совместимости в описании SET TRANSACTION.
См. также
BEGIN, COMMIT, ROLLBACK, SAVEPOINT, SET TRANSACTIONSTART TRANSACTION
START TRANSACTION — start a transaction block
Synopsis
START TRANSACTION [transaction_mode
[, ...] ] wheretransaction_mode
is one of: ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED } READ WRITE | READ ONLY [ NOT ] DEFERRABLE
Description
This command begins a new transaction block. If the isolation level, read/write mode, or deferrable mode is specified, the new transaction has those characteristics, as if SET TRANSACTION was executed. This is the same as the BEGIN command.
Parameters
Refer to SET TRANSACTION for information on the meaning of the parameters to this statement.
Compatibility
In the standard, it is not necessary to issue START TRANSACTION
to start a transaction block: any SQL command implicitly begins a block. Postgres Pro's behavior can be seen as implicitly issuing a COMMIT
after each command that does not follow START TRANSACTION
(or BEGIN
), and it is therefore often called “autocommit”. Other relational database systems might offer an autocommit feature as a convenience.
The DEFERRABLE
transaction_mode
is a Postgres Pro language extension.
The SQL standard requires commas between successive transaction_modes
, but for historical reasons Postgres Pro allows the commas to be omitted.
See also the compatibility section of SET TRANSACTION.