START TRANSACTION — 开始一个事务块
START TRANSACTION [transaction_mode
[, ...] ] wheretransaction_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
,因此它通常被称为“autocommit”。其他关系数据库系统可能会提供 autocommit 功能作为一种便利。
DEFERRABLE
事务模式是 PostgreSQL 语言的扩展。
SQL 标准要求在连续的 transaction_modes
之间使用逗号分隔,但出于历史原因,PostgreSQL 允许省略逗号。
另请参阅 SET TRANSACTION 的兼容性部分。
如果您在文档中看到任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。