2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3

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的兼容性部分。

提交更正

如果您在文档中发现任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用此表单报告文档问题。