【趙強老師】數據庫的事務

1、什麼是事務?sql

數據庫事務(Transaction)是訪問並可能操做各類數據項的一個數據庫操做序列,這些操做要麼所有執行,要麼所有不執行,是一個不可分割的工做單位。事務由事務開始與事務結束之間執行的所有數據庫操做組成。數據庫

例如:從A帳號給B帳號轉賬,對應於以下兩條sql語句
update from account set money=money+100 where name=‘b’;
update from account set money=money-100 where name=‘a’;

這兩條update語句應該做爲一個總體來運行,要保證同時成功,或者同時失敗;不該該存在一個成功,一個失敗的狀況。併發

2、數據庫開啓事務命令spa

咱們可使用下面的語句來開啓或者結束一個事務。線程

  • start transaction  開啓事務
  • rollback 回滾事務
  • commit 提交事務

例如,咱們能夠把上面的銀行轉帳的update語句放到一個事務中執行。code

start transaction;
update from account set money=money+100 where name=‘b’;
update from account set money=money-100 where name=‘a’;
commit;

3、事務的特徵:ACID事務

  • 原子性(Atomicity):原子性是指事務是一個不可分割的工做單位,事務中的操做要麼都發生,要麼都不發生。
  • 一致性(Consistency):事務必須使數據庫從一個一致性狀態變換到另一個一致性狀態。
  • 隔離性(Isolation):事務的隔離性是多個用戶併發訪問數據庫時,數據庫爲每個用戶開啓的事務,不能被其餘事務的操做數據所幹擾,多個併發事務之間要相互隔離。
  • 持久性(Durability):持久性是指一個事務一旦被提交,它對數據庫中數據的改變就是永久性的,接下來即便數據庫發生故障也不該該對其有任何影響。

4、事務的隔離級別ci

多個線程開啓各自事務操做數據庫中數據時,數據庫系統要負責隔離操做,以保證各個線程在獲取數據時的準確性。rem

若是不考慮隔離性,可能會引起以下問題:it

  • 髒讀:指一個事務讀取了另一個事務未提交的數據。
  • 不可重複讀:在一個事務內讀取表中的某一行數據,屢次讀取結果不一樣。
  • 虛讀(幻讀):是指在一個事務內讀取到了別的事務插入的數據,致使先後讀取不一致。

數據庫共定義了四種隔離級別:

Serializable:可避免髒讀、不可重複讀、虛讀狀況的發生。(串行化)
Repeatable read(MySQL的默認值):可避免髒讀、不可重複讀狀況的發生。(可重複讀)
Read committed:可避免髒讀狀況發生(讀已提交)。
Read uncommitted:最低級別,以上狀況均沒法保證。(讀未提交)

咱們能夠能夠經過下面的語句來查看MySQL的事務隔離級別和設置隔離級別:

set (GLOBAL|SESSION) transaction isolation level 設置事務隔離級別
select @@tx_isolation 查詢當前事務隔離級別

下面的語句將查看MySQL數據庫當前的事務隔離級別。

下面的語句將MySQL的事務隔離級別設置成read committed,在這種隔離級別下,將會發生髒讀的問題。

相關文章
相關標籤/搜索