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

BEGIN

BEGIN — 开始一个事务块

Synopsis

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

其中 transaction_mode 是下列之一:

    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 TRANSACTIONBEGIN具有相同功能。

使用COMMITROLLBACK 可以结束一个事务块。

如果在已经处于事务块中时发出BEGIN,将会产生一条警告消息。 事务状态不会受影响。 若要在事务块中实现事务嵌套,请使用保存点 (参见SAVEPOINT)。

出于向后兼容的考虑,连续多个transaction_modes 之间的逗号可以省略。

示例

开始一个事务块:

BEGIN;

兼容性

BEGINPostgreSQL的一种语言扩展。 它等价于 SQL 标准命令 START TRANSACTION, 后者的参考页中包含更多兼容性信息。

DEFERRABLE transaction_modePostgreSQL的一种语言扩展。

另外,在嵌入式 SQL 中,关键字BEGIN用于不同的目的。 在移植数据库应用程序时,应当谨慎处理事务语义。

提交更正

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