BEGIN — 启动一个事务块
BEGIN [ WORK | TRANSACTION ] [transaction_mode[, ...] ] wheretransaction_modeis 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 一样。
START TRANSACTION 具有与 BEGIN 相同的功能。
当已在事务块内时发出 BEGIN 将会引发警告消息。事务的状态不受影响。要在事务块内嵌套事务,请使用保存点(请参阅 SAVEPOINT)。
出于向后兼容性的原因,可以省略连续 transaction_modes 之间的逗号。
开始一个事务块:
BEGIN;
BEGIN 是 PostgreSQL 语言的扩展。它等同于 SQL 标准命令 START TRANSACTION,其参考页面包含其他兼容性信息。
DEFERRABLE transaction_mode 是 PostgreSQL 语言的扩展。
顺便说一句,BEGIN 关键字在嵌入式 SQL 中用于不同的目的。在移植数据库应用程序时,建议您注意事务语义。
如果您在文档中发现任何不正确、与您使用特定功能的经验不符或需要进一步澄清的地方,请使用此表单报告文档问题。