BEGIN
BEGIN — 开始事务块
语法
BEGIN [ WORK | TRANSACTION ] [ transaction_mode [, ...] ]
where transaction_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以“自动提交”模式执行事务,即,每条语句都在自己的事务中执行,并且在语句结束时隐式执行提交(如果执行成功,否则执行回滚)。
在事务块中执行语句的速度更快,因为事务启动/提交需要大量的 CPU 和磁盘活动。在一个事务中执行多条语句还有助于确保在进行多个相关更改时的一致性:其他会话将无法看到中间状态,其中尚未完成所有相关的更新。
如果指定了隔离级别、读/写模式或可推迟模式,则新事务将具有这些特性,就像执行了SET TRANSACTION
一样。
参数
WORK
TRANSACTION
可选关键字。它们没有效果。
有关此语句其他参数含义的信息,请参阅SET TRANSACTION。
注释
START TRANSACTION
的功能与BEGIN
相同。
在已经处于事务块中时发出BEGIN
将引发一条警告消息。事务的状态不受影响。要在事务块中嵌套事务,请使用保存点(请参阅SAVEPOINT)。
出于向后兼容性的原因,可以省略连续*transaction_modes
*之间的逗号。
示例
开始一个事务块
BEGIN;
兼容性
BEGIN
是PostgreSQL语言扩展。它等效于 SQL 标准命令START TRANSACTION
,其参考页面包含其他兼容性信息。
DEFERRABLE
*transaction_mode
*是PostgreSQL语言扩展。
顺便提一下,BEGIN
关键字在嵌入式 SQL 中用于不同的目的。在移植数据库应用程序时,建议您注意事务语义。