W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
TRANSACTION(事務)是數(shù)據(jù)庫管理系統(tǒng)執(zhí)行過程中的一個邏輯單位,由一個有限的數(shù)據(jù)庫操作序列構成。
數(shù)據(jù)庫事務通常包含了一個序列的對數(shù)據(jù)庫的讀/寫操作。包含有以下兩個目的:
當事務被提交給了數(shù)據(jù)庫管理系統(tǒng)(DBMS),則 DBMS 需要確保該事務中的所有操作都成功完成且其結果被永久保存在數(shù)據(jù)庫中,如果事務中有的操作沒有成功完成,則事務中的所有操作都需要回滾,回到事務執(zhí)行前的狀態(tài);同時,該事務對數(shù)據(jù)庫或者其他事務的執(zhí)行無影響,所有的事務都好像在獨立的運行。
事務具有以下四個標準屬性,通常根據(jù)首字母縮寫為 ACID:
某人要在商店使用電子貨幣購買100元的東西,當中至少包括兩個操作:
支持事務的數(shù)據(jù)庫管理系統(tǒng)就是要確保以上兩個操作(整個"事務")都能完成,或一起取消,否則就會出現(xiàn) 100 元平白消失或出現(xiàn)的情況。
使用下面的命令來控制事務:
事務控制命令只與 INSERT、UPDATE 和 DELETE 一起使用。他們不能在創(chuàng)建表或刪除表時使用,因為這些操作在數(shù)據(jù)庫中是自動提交的。
事務可以使用 BEGIN TRANSACTION 命令或簡單的 BEGIN 命令來啟動。此類事務通常會持續(xù)執(zhí)行下去,直到遇到下一個 COMMIT 或 ROLLBACK 命令。不過在數(shù)據(jù)庫關閉或發(fā)生錯誤時,事務處理也會回滾。以下是啟動一個事務的簡單語法:
BEGIN; 或者 BEGIN TRANSACTION;
COMMIT 命令是用于把事務調用的更改保存到數(shù)據(jù)庫中的事務命令,即確認事務。
COMMIT 命令的語法如下:
COMMIT; 或者 END TRANSACTION;
ROLLBACK 命令是用于撤消尚未保存到數(shù)據(jù)庫的事務命令,即回滾事務。
ROLLBACK 命令的語法如下:
ROLLBACK;
創(chuàng)建 COMPANY 表 ,數(shù)據(jù)內容如下:
w3cschooldb# select * from COMPANY; id | name | age | address | salary ----+-------+-----+-----------+-------- 1 | Paul | 32 | California| 20000 2 | Allen | 25 | Texas | 15000 3 | Teddy | 23 | Norway | 20000 4 | Mark | 25 | Rich-Mond | 65000 5 | David | 27 | Texas | 85000 6 | Kim | 22 | South-Hall| 45000 7 | James | 24 | Houston | 10000 (7 rows)
現(xiàn)在,讓我們開始一個事務,并從表中刪除 age = 25 的記錄,最后,我們使用 ROLLBACK 命令撤消所有的更改。
w3cschooldb=# BEGIN; DELETE FROM COMPANY WHERE AGE = 25; ROLLBACK;
檢查 COMPANY 表,仍然有以下記錄:
id | name | age | address | salary ----+-------+-----+-----------+-------- 1 | Paul | 32 | California| 20000 2 | Allen | 25 | Texas | 15000 3 | Teddy | 23 | Norway | 20000 4 | Mark | 25 | Rich-Mond | 65000 5 | David | 27 | Texas | 85000 6 | Kim | 22 | South-Hall| 45000 7 | James | 24 | Houston | 10000
現(xiàn)在,讓我們開始另一個事務,從表中刪除 age = 25 的記錄,最后我們使用 COMMIT 命令提交所有的更改。
w3cschooldb=# BEGIN; DELETE FROM COMPANY WHERE AGE = 25; COMMIT;
檢查 COMPANY 表,記錄已被刪除:
id | name | age | address | salary ----+-------+-----+------------+-------- 1 | Paul | 32 | California | 20000 3 | Teddy | 23 | Norway | 20000 5 | David | 27 | Texas | 85000 6 | Kim | 22 | South-Hall | 45000 7 | James | 24 | Houston | 10000 (5 rows)
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: