デフォルトでは、Postgres は トランザクションを 非連鎖モード (他のデータベースシステムでは "自動コミット" としても知られています) で実行します。 別の言葉で言えば、それぞれのユーザの文はそれ固有のトランザクションの中で 実行され、コミットはその文の終わりに暗黙的に実行されます (実行が成功した 場合であり、そうでない場合はロールバックされます)。 BEGIN はユーザのトランザクションを連鎖 モードで開始します。すなわち、BEGIN コマンド以降の 全てのユーザの文は、明示的な COMMIT、 ROLLBACK もしくは実行のアボートまでの単一のトランザクションにおいて実行されます。 連鎖モードにおける文はとても迅速に実行されます。なぜなら トランザクション の開始/コミットはCPUとディスクにかなり高いを要求するからです。 トランザクション中の複数の文の実行はまた、複数の関連するテーブルを更新 する時に一貫性が要求されます。
Postgres におけるデフォルトのトランザクション 隔離レベルは、トランザクション内の問い合わせが問い合わせ実行前にコミット された変更のみが参照できる READ COMMITTED です。 したがって、より厳密な トランザクションの隔離を必要とするならば、BEGIN のすぐ後に SET TRANSACTION ISOLATION LEVEL SERIALIZABLE を使わなければなりません。 SERIALIZABLE モードでは、問い合わせは トランザクションの全体が開始される以前にコミットされた変更のみを 参照します (実際には、シリアライザブルなトランザクション中の最初のDML 文の実行以前です)。
もしトランザクションがコミットされたら、 Postgres は全ての更新が行なうか、もしくは更新を行なわないかのどちらかです。 トランザクションには、標準の ACID 性 (atomic(原子性), consistent(一貫性), isolatable(隔離性), durable(耐久性)) があります。
BEGIN は Postgres の言語拡張です。SQL92 には明示的な BEGIN コマンドはありません。トランザクションの 開始は常に暗黙的で、COMMIT または ROLLBACK 文で終了します。
Note: 便宜をはかるため、多くのリレーショナルデータベースシステムは、自動コミット 機能を提供しています。
ついでに、キーワード BEGIN は埋め込み SQL で 異なった目的に使われます。データベースアプリケーションを 移植するときはトランザクションの意味で使用されているのかどうか 注意することをお勧めします。
SQL92 は更に SEREALIZABLE がデフォルトトランザクション 隔離レベルであることを要求しています。