受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

START TRANSACTION

START TRANSACTION — 开始一个事务块

Synopsis

START TRANSACTION [ transaction_mode [, ...] ]

其中 transaction_mode 是下列之一:

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

描述

该命令开始一个新的事务块。如果指定了隔离级别、读写模式或可延迟模式, 新事务就会具有这些特性,就像执行了 SET TRANSACTION一样。 它与BEGIN命令具有相同功能。

参数

关于本语句参数含义的信息,参见SET TRANSACTION

兼容性

在 SQL 标准中,并不需要发出START TRANSACTION 来开始一个事务块:任何 SQL 命令都会隐式开始一个事务块。 PostgreSQL的行为可以看作是:对每条不跟在 START TRANSACTION(或BEGIN)之后的命令, 都会在其后隐式发出一个COMMIT,因此这种行为通常被称为 自动提交。其他关系型数据库系统也可能为了方便而提供 自动提交特性。

DEFERRABLE 这一 transaction_modePostgreSQL语言扩展。

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

另见SET TRANSACTION的兼容性小节。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。