noble (7) begin.7.gz

Provided by: manpages-zh_1.6.4.0-1_all bug

NAME

       BEGIN - 開始一個事務塊

SYNOPSIS

       BEGIN [ WORK | TRANSACTION ]

DESCRIPTION 描述

       BEGIN  初始化一個事務塊,  也就是說所有 BEGIN  命令後的使用者語句都將在一個事務裡面執行直到給出一個明確的
       COMMIT [commit(7)] 或者 ROLLBACK [rollback(l)] 。 預設時,(沒有 BEGIN),PostgreSQL 以 "autocommit"   模
       式執行事務,也就是說,每個語句在其自身的事務中執行,   並且在語句結束的時候隱含地執行一個提交(如果執行成
       功,否則執行回滾)。

        在事務塊裡執行的語句很明顯地快得多,  因為事務開始/提交(start/commit)需要大量的CPU和磁碟活動。  在一個
       事務內部執行多條語句對於修改若干個相關的表的時候也是很有用的: 在所有相關的更新完成之前,其它會話看不到中
       間的狀態。

PARAMETERS 引數

       WORK

       TRANSACTION
               可選關鍵字。沒什麼作用。

NOTES 注意

       START TRANSACTION [start_transaction(7)] 有著和 BEGIN 一樣的功能。

        使用 COMMIT [commit(7)] 或 ROLLBACK [rollback(7)] 結束一個事務。

        在一個現有事務塊內部發出一個 BEGIN 將產生一個警告資訊。 事務的狀態將不會被影響。

EXAMPLES 例子

        開始一個使用者事務:

       BEGIN;

COMPATIBILITY 相容性

       BEGIN 是 PostgreSQL 語言的擴充套件。 在 SQL  標準中沒有明確的 BEGIN  的定義;事務初始化總是隱含的而且使用
       一個 COMMIT 或者 ROLLBACK 語句終止。

        許多關係型資料庫為了方便提供一個自動提交(autocommit)特性。

        順便說一句,BEGIN 關鍵字在嵌入 SQL 裡用於不同的目的。 我們建議你在移植資料庫應用時仔細檢查事務的語義。

SEE ALSO 參見

       COMMIT [commit(7)], ROLLBACK [rollback(l)]

譯者

       Postgresql 中文網站 何偉平 <laser@pgsqldb.org>

       本頁面中文版由中文 man 手冊頁計劃提供。
       中文 man 手冊頁計劃:https://github.com/man-pages-zh/manpages-zh