受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: 19 / devel
此文档适用于不受支持的 PostgreSQL 版本。
您可能需要查看当前版本的相同页面,或上面列出的其他受支持版本。

COMMIT

COMMIT — 提交当前事务

Synopsis

COMMIT [ WORK | TRANSACTION ] [ AND [ NO ] CHAIN ]

描述

COMMIT提交当前事务。 该事务所做的所有更改都会对其他会话可见, 并且如果发生崩溃,也能保证其持久性。

如果该事务处于已中止状态,则不会做出任何更改, 且 COMMIT 的效果将与 ROLLBACK 完全相同, 包括命令标签输出在内。

无论哪种情况,如果指定了 AND CHAIN 参数, 都会启动一个配置完全相同的新事务。

有关事务的更多信息,见Section 3.4

参数

WORK
TRANSACTION #

可选关键字,没有任何作用。

AND CHAIN #

如果指定了AND CHAIN,则会立即启动一个新事务, 其事务特征与刚刚结束的事务相同(参见SET TRANSACTION)。 否则,不会启动任何新事务。

输出

当未中止的事务成功完成时, COMMIT 命令返回如下形式的命令标签:

COMMIT

但是,在已中止的事务中,COMMIT 命令返回如下形式的命令标签:

ROLLBACK

注解

使用ROLLBACK可中止一个事务。

在事务块之外发出COMMIT不会造成任何影响,但会产生一条警告消息。 事务块之外的COMMIT AND CHAIN则会报错。

示例

提交当前事务,并使所有更改永久生效:

COMMIT;

兼容性

命令COMMIT符合 SQL 标准,但有一个例外: 当事务已被中止时,不会引发异常条件。

形式COMMIT TRANSACTION是 PostgreSQL 扩展。