Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

START TRANSACTION

START TRANSACTION — 启动一个事务块

简介

START TRANSACTION [ transaction_mode [, ...] ]

where transaction_mode is one of:

    ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED }
    READ WRITE | READ ONLY
    [ NOT ] DEFERRABLE

说明

此命令启动一个新事务块。如果指定了隔离级别、读/写模式或可推迟模式,则新事务具有这些特征,如同执行了 SET TRANSACTION 一样。这与 BEGIN 命令相同。

参数

有关此语句参数含义的信息,请参阅 SET TRANSACTION

兼容性

在标准中,不需要发出 START TRANSACTION 来启动一个事务块:任何 SQL 命令都隐式地开始一个块。 PostgreSQL 的行为可以视作在未执行 START TRANSACTION(或 BEGIN)的每个命令后隐式地发出 COMMIT,因此它通常被称为 自动提交。其他关系数据库系统可能会作为一种便利来提供自动提交功能。

DEFERRABLE transaction_modePostgreSQL 语言扩展。

SQL 标准要求在连续的 transaction_modes 之间使用逗号,但由于历史原因,PostgreSQL 允许省略逗号。

同时参阅 SET TRANSACTION 的兼容性部分。

另请参见

BEGINCOMMITROLLBACKSAVEPOINTSET TRANSACTION