START TRANSACTION [ transaction_mode [, ...] ]
这里的 transaction_mode是下列之一:
ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED }
READ WRITE | READ ONLY
[ NOT ] DEFERRABLE
在标准里,没必要声明START TRANSACTION来开始一个事务块: 任何 SQL 语句都隐含地开始一个事务块。PostgreSQL 的行为可以认为是隐含地在每条没有跟在START TRANSACTION或BEGIN 后面的命令自动发出一条COMMIT,因此这个行为常被称作"自动提交"。 其它关系数据库系统可能也提供自动提交这一方便的特性。
DEFERRABLE transaction_mode 是一个PostgreSQL语言扩展。
SQL 标准要求在相连的transaction_modes 之间有逗号,但是出于历史原因,PostgreSQL允许省略这个逗号。
又见SET TRANSACTION的兼容性小节。