2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 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 / 7.2 / 7.1

BEGIN

BEGIN — 开始一个事务块

概要

BEGIN [ WORK | TRANSACTION ] [ transaction_mode [, ...] ]

where transaction_mode is one of:

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

描述

BEGIN 启动一个事务块,也就是说,在 BEGIN 命令之后的所有语句都将在单个事务中执行,直到显式发出 COMMITROLLBACK 为止。默认情况下(不带 BEGIN),PostgreSQL 以“自动提交”模式执行事务,即每个语句都在自己的事务中执行,并在语句末尾隐式执行提交(如果执行成功,否则执行回滚)。

事务块中的语句执行速度更快,因为事务开始/提交需要大量的 CPU 和磁盘活动。在事务中执行多个语句也有助于确保在进行多项相关更改时的一致性:其他会话将无法看到中间状态,即尚未完成所有相关更新的状态。

如果指定了隔离级别、读/写模式或可延迟模式,则新事务具有这些特性,如同执行了 SET TRANSACTION

参数

WORK
TRANSACTION

可选关键字。它们没有效果。

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

注释

START TRANSACTION 具有与 BEGIN 相同的功能。

使用 COMMITROLLBACK 来终止事务块。

当已在事务块内时发出 BEGIN 会引起警告消息。事务的状态不受影响。要在一个事务块内嵌套事务,请使用保存点(参见 SAVEPOINT)。

出于向后兼容的原因,连续 transaction_modes 之间的逗号可以省略。

示例

开始一个事务块

BEGIN;

兼容性

BEGINPostgreSQL 的语言扩展。它等同于 SQL 标准命令 START TRANSACTION,其参考页面包含其他兼容性信息。

DEFERRABLE transaction_modePostgreSQL 的语言扩展。

顺便说一下,BEGIN 关键字在嵌入式 SQL 中用于不同的目的。建议在移植数据库应用程序时注意事务语义。

提交更正

如果您在文档中看到任何不正确、不符合您对特定功能的实际经验或需要进一步澄清的内容,请使用 此表单 报告文档问题。