事务的概述
1.基本概念
- 將一條或者多條SQL看成一個(gè)整體,要么同時(shí)執(zhí)行成功要么同時(shí)執(zhí)行失敗,這就是事務(wù)。
事務(wù)舉例:
張三給李四轉(zhuǎn)賬500元錢,需要讓三賬戶的余額-500,李四的賬戶余額+500,轉(zhuǎn)賬是一個(gè)連續(xù)的過程,要么同時(shí)成功,要么同時(shí)失敗。不能出現(xiàn)張三轉(zhuǎn)出了500塊,而李四沒收到的情況,這將是很嚴(yán)重的問題。
2.事務(wù)的基本使用
執(zhí)行SQL語句之前開啟事務(wù),執(zhí)行后沒異常就提交,有異常就回滾
<1>開啟事務(wù):在執(zhí)行一組sQL操作之前開始事務(wù),start transaction;
提交了之后是不是不能回滾
<2>提交事務(wù):在一組sQL執(zhí)行成功之后提交事務(wù),commit;
如果開啟事務(wù)不提交,那么默認(rèn)就是回滾【斷開連接】
<3>回滾事務(wù):在一組SQL執(zhí)行出現(xiàn)異常之后回滾事務(wù),rollback;
舉例【執(zhí)行后,發(fā)現(xiàn)查詢結(jié)果出錯(cuò)則回滾,正確則提交】:
-- 張三給李四轉(zhuǎn)賬500元-- 開啟事務(wù) START TRANSACTION;-- 1.張三賬戶-500 UPDATE account SET money=money-500 WHERE NAME='張三';出錯(cuò)了...-- 2.李四賬戶+500 UPDATE account SET money=money+500 WHERE NAME='李四';-- 回滾事務(wù) ROLLBACK;-- 提交事務(wù) COMMIT;補(bǔ)充–try里面使用commit提交事務(wù),catch里面使用rollback回滾事務(wù)
3.事務(wù)的提交方式
1代表自動(dòng)提交 0代表手動(dòng)提交[COMMIT;]
- 查詢事務(wù)提交方式:SELECT @@AUTOCOMMIT;
- 修改事務(wù)提交方式:SET @@AUTOCOMMIT=數(shù)字;
4.事務(wù)的四大特征(ACID)
<1> 原子性(Atomicity)
原子性是指事務(wù)包含的所有操作要么全部成功,要么全部失敗回滾。
因此事務(wù)的操作如果成功就必須要完全應(yīng)用到數(shù)據(jù)庫,如果操作失敗則不能對數(shù)據(jù)庫有任何影響。
<2> 一致性(Consistency)
一致性是指事務(wù)必須使數(shù)據(jù)庫從一個(gè)一致性狀態(tài)變換到另一個(gè)一致性狀態(tài)。
也就是說一個(gè)事務(wù)執(zhí)行之前和執(zhí)行之后都必須處于一致性狀態(tài)。
<3> 隔離性(isolcation)
隔離性是當(dāng)多個(gè)用戶并發(fā)訪問數(shù)據(jù)庫時(shí),比如操作同一張表時(shí),數(shù)據(jù)庫為每一個(gè)用戶開啟的事務(wù)。
不能被其他事務(wù)的操作所干擾,多個(gè)并發(fā)事務(wù)之間要相互隔離。
<4> 持久性(durability)
持久性是指一個(gè)事務(wù)一旦被提交了,那么對數(shù)據(jù)庫中的數(shù)據(jù)的改變就是永久性的。
即便是在數(shù)據(jù)庫系統(tǒng)遇到故障的情況下也不會(huì)丟失提交事務(wù)的操作。
5.事務(wù)的隔離級(jí)別
- 多個(gè)事務(wù)之間是隔離的,相互獨(dú)立的。但是如果多個(gè)事務(wù)操作同一批數(shù)據(jù),則會(huì)引發(fā)一些問題,設(shè)置不同的隔離級(jí)別就可以解決這些問題。
- 產(chǎn)生條件是要在兩個(gè)新連接中操作【如兩臺(tái)電腦,獲取一臺(tái)電腦連接數(shù)據(jù)庫兩次】,不是一個(gè)連接中的兩個(gè)查詢窗口。
<1>設(shè)置隔離級(jí)別
可重復(fù)讀:兩次讀取的數(shù)據(jù)一樣
不可重復(fù)讀:兩次讀取的數(shù)據(jù)不一樣【問題:多人操作時(shí)所看到的數(shù)據(jù)有差異】
<2>存在的問題
<3>查詢隔離級(jí)別以及設(shè)置隔離級(jí)別
-
數(shù)據(jù)庫查詢隔離級(jí)別:
select @@tx_isolation;
-
數(shù)據(jù)庫設(shè)置隔離級(jí)別(修改后需要重新連接):
set global transaction isolation level 級(jí)別字符串;
總結(jié)