登录
开始事务
START TRANSACTION — 开始一个事务块
概要
START TRANSACTION [ transaction_mode [, ...] ]
where transaction_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的兼容性部分。