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