您好,登錄后才能下訂單哦!
本篇文章為大家展示了mysql數據庫的事務指的是什么,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
一、什么是事務?
數據庫事務(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語句應該作為一個整體來運行,要保證同時成功,或者同時失敗;不應該存在一個成功,一個失敗的情況。
二、數據庫開啟事務命令
我們可以使用下面的語句來開啟或者結束一個事務。
start transaction 開啟事務
rollback 回滾事務
commit 提交事務
例如,我們可以把上面的銀行轉賬的update語句放到一個事務中執行。
start transaction; update from account set money=money+100 where name=‘b’; update from account set money=money-100 where name=‘a’; commit;
三、事務的特征:ACID
原子性(Atomicity):原子性是指事務是一個不可分割的工作單位,事務中的操作要么都發生,要么都不發生。
一致性(Consistency):事務必須使數據庫從一個一致性狀態變換到另外一個一致性狀態。
隔離性(Isolation):事務的隔離性是多個用戶并發訪問數據庫時,數據庫為每一個用戶開啟的事務,不能被其他事務的操作數據所干擾,多個并發事務之間要相互隔離。
持久性(Durability):持久性是指一個事務一旦被提交,它對數據庫中數據的改變就是永久性的,接下來即使數據庫發生故障也不應該對其有任何影響。
四、事務的隔離級別
多個線程開啟各自事務操作數據庫中數據時,數據庫系統要負責隔離操作,以保證各個線程在獲取數據時的準確性。
如果不考慮隔離性,可能會引發如下問題:
臟讀:指一個事務讀取了另外一個事務未提交的數據。
不可重復讀:在一個事務內讀取表中的某一行數據,多次讀取結果不同。
虛讀(幻讀):是指在一個事務內讀取到了別的事務插入的數據,導致前后讀取不一致。
數據庫共定義了四種隔離級別:
Serializable:可避免臟讀、不可重復讀、虛讀情況的發生。(串行化) Repeatable read(MySQL的默認值):可避免臟讀、不可重復讀情況的發生。(可重復讀) Read committed:可避免臟讀情況發生(讀已提交)。 Read uncommitted:最低級別,以上情況均無法保證。(讀未提交)
我們可以可以通過下面的語句來查看MySQL的事務隔離級別和設置隔離級別:
set (GLOBAL|SESSION) transaction isolation level 設置事務隔離級別 select @@tx_isolation 查詢當前事務隔離級別
下面的語句將查看MySQL數據庫當前的事務隔離級別。
下面的語句將MySQL的事務隔離級別設置成read committed,在這種隔離級別下,將會發生臟讀的問題。
上述內容就是mysql數據庫的事務指的是什么,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。