BEGIN — 开始事务区块
BEGIN [ WORK | TRANSACTION ] [transaction_mode
[, ...] ] wheretransaction_mode
is one of: ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED } READ WRITE | READ ONLY [ NOT ] DEFERRABLE
BEGIN
启动一个事务区块,也就是说,在 BEGIN
命令后,所有语句将在单个事务中执行,直到明确出现 COMMIT
或 ROLLBACK
。在默认情况下(不使用 BEGIN
),PostgreSQL 使用 “autocommit” 模式执行事务,也就是说,每个语句都在它自己的事务中执行,并且在语句结束时(如果执行成功,否则执行回滚)隐式执行一次提交。
在事务块中执行语句的速度更快,因为事务开始/提交需要大量的 CPU 和磁盘活动。在事务中执行多条语句还有助于确保在进行多个相关更改时的一致性:其他会话将无法查看相关更新尚未完成的中间状态。
如果指定了隔离级别、读/写模式或可延迟模式,新事务将具有这些特性,就像执行了 SET TRANSACTION
一样。
START TRANSACTION
与 BEGIN
具有相同的功能。
当已处于事务块中时发出 BEGIN
会引发警告消息。这不会影响事务的状态。要在事务块中嵌套事务,请使用保存点(请参阅 SAVEPOINT)。
出于向后兼容性的原因,可以省略连续 transaction_modes
之间的逗号。
开始事务块
BEGIN;
BEGIN
是 PostgreSQL 语言扩展。它等效于 SQL 标准命令 START TRANSACTION
,其参考页包含其他兼容性信息。
DEFERRABLE
transaction_mode
是 PostgreSQL 语言扩展。
顺便提一下,BEGIN
关键字在嵌入式 SQL 中用于不同的用途。建议你在移植数据库应用程序时注意事务语义。