欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql事務特性和級別原理解析

 更新時間:2020年12月08日 11:53:58   作者:北方有魚  
這篇文章主要介紹了Mysql事務特性和級別原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

一、什么是事務?

數據庫事務(簡稱:事務)是數據庫管理系統(tǒng)執(zhí)行過程中的一個邏輯單位,由一個有限的數據庫操作序列構成。

二、事務的四大屬性

分別是原子性、一致性、隔離性、持久性。

1、原子性(Atomicity)

原子性是指事務包含的所有操作要么全部成功,要么全部失敗回滾,因此事務的操作如果成功就必須要完全應用到數據庫,如果操作失敗則不能對數據庫有任何影響。

2、一致性(Consistency)

一致性是指事務必須使數據庫從一個一致性狀態(tài)變換到另一個一致性狀態(tài),也就是說一個事務執(zhí)行之前和執(zhí)行之后都必須處于一致性狀態(tài)。舉例來說,假設用戶A和用戶B兩者的錢加起來一共是1000,那么不管A和B之間如何轉賬、轉幾次賬,事務結束后兩個用戶的錢相加起來應該還得是1000,這就是事務的一致性。

3、隔離性(Isolation)

隔離性是當多個用戶并發(fā)訪問數據庫時,比如同時操作同一張表時,數據庫為每一個用戶開啟的事務,不能被其他事務的操作所干擾,多個并發(fā)事務之間要相互隔離。關于事務的隔離性數據庫提供了多種隔離級別,稍后會介紹到。

4、持久性(Durability)

持久性是指一個事務一旦被提交了,那么對數據庫中的數據的改變就是永久性的,即便是在數據庫系統(tǒng)遇到故障的情況下也不會丟失提交事務的操作。例如我們在使用JDBC操作數據庫時,在提交事務方法后,提示用戶事務操作完成,當我們程序執(zhí)行完成直到看到提示后,就可以認定事務已經正確提交,即使這時候數據庫出現了問題,也必須要將我們的事務完全執(zhí)行完成。否則的話就會造成我們雖然看到提示事務處理完畢,但是數據庫因為故障而沒有執(zhí)行事務的重大錯誤。這是不允許的。

三、mysql隔離級別 

READ UNCOMMITTED(未提交讀)

在未提交讀這個事務級別中,一個事務可以讀取到另外一個事務未提交的數據.
例如 A 事務更新了一個字段,但是未提交在 B 事務中,讀取id為1000的記錄的name字段的時候,name的值為'aaa',可是 A 事務并沒有commit,所以name = 'aaa'有可能是會被回滾的,那么,A 事務讀取了未提交事務的數據稱為臟讀(Dirty Read)

READ COMMITTED(提交讀)

提交讀這個事務級別中,一個事務可以讀取到另外一個事務提交之后的數據.

例如 A 事務讀取到了id為1000的記錄的name字段為aaa ,然后 B 事務這個時候更新了這條記錄的name值,并且提交了,這個時候 A 事務再次讀取name的話,name的值就是bbb了,所以在一個事務中,對一個字段進行多次讀取,可能得到的值不同.

A事務前后兩次讀取的值不一致!

REPEATABLE READ(可重復讀)

可重復讀這個事務級別中,一個事務重復去讀的字段不會改變.

例如 A 事務讀取到了id為1000的記錄的name值為aaa,然后 B 事務中把name改成了bbb,并且 B 事務提交了,A 事務再次去讀name的時候并不會讀取到bbb,所以 A 事務相當于在一個獨立的世界,外界的任何改動不會影響 A 事務.

但是,可重復讀會導致幻讀出現,什么是幻讀呢,舉個例子:
A 事務查詢一個表,表里只有一條記錄,id為1,但是這個時候 B 事務插入了一條數據,id為2,A 事務因為不知道有id為2的數據,所以這個時候A也插入了一條id為2的數據,這個時候肯定會插入失敗.這種情況就是幻讀

備注: MYSQL中的innoDB通過MVCC(多版本并發(fā)控制)解決了幻讀,另外MYSQL的默認事務級別就是可重復讀,Oracle和SQL Server 默認隔離級別為 已提交讀(Read committed)

SERIALIZABLE(可串行化)

可串行化事務級別,把讀取的每一行數據都加了鎖

加鎖了的有點就是,避免了臟讀和幻讀,另外還避免了不可重復讀的可能性,但是因為加鎖了,減少了很大的并發(fā)性,因為同一時刻,只有一個線程能夠獲取到鎖.還可能導致大量超時問題.

小結:不可重復讀的和幻讀很容易混淆,不可重復讀側重于修改,幻讀側重于新增或刪除。解決不可重復讀的問題只需鎖住滿足條件的行,解決幻讀需要鎖表

隔離級別:

隔離級別 臟讀(Dirty Read) 不可重復讀(NonRepeatable Read) 幻讀(Phantom Read)
未提交讀(Read uncommitted) 可能 可能 可能    
已提交讀(Read committed) 不可能 可能 可能
可重復讀(Repeatable read) 不可能 不可能 可能
可串行化(Serializable ) 不可能 不可能 不可能

級別越高,數據越安全,但性能越低。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • MySQL權限變更何時生效

    MySQL權限變更何時生效

    本文為大家講述了對三種級別權限的變更后,使其生效的方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>
    2023-10-10
  • MySQL?去重實例操作詳解

    MySQL?去重實例操作詳解

    這篇文章主要介紹了MySQL?去重實例操作詳情,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • 安裝MySQL時,輸入mysqld --install后,顯式該文件已存在問題

    安裝MySQL時,輸入mysqld --install后,顯式該文件已存在問題

    這篇文章主要介紹了安裝MySQL時,輸入mysqld --install后,顯式該文件已存在問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Mysql的DQL查詢操作全面分析講解

    Mysql的DQL查詢操作全面分析講解

    DQL(Data Query Language 數據查詢語言):用于查詢數據庫對象中所包含的數據。DQL語言主要的語句:SELECT語句。DQL語言是數據庫語言中最核心、最重要的語句,也是使用頻率最高的語句
    2022-12-12
  • MySQL自增ID耗盡實例講解

    MySQL自增ID耗盡實例講解

    這篇文章主要給大家介紹了關于MySQL自增ID耗盡的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Mysql具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03
  • MySQL中EXPLAIN的/基本使用及字段詳解

    MySQL中EXPLAIN的/基本使用及字段詳解

    EXPLAIN命令是MySQL中用于解析SQL查詢語句的工具,幫助開發(fā)者理解MySQL如何執(zhí)行SQL語句,通過EXPLAIN可以查看SQL執(zhí)行的詳細信息,如表的讀取順序、使用的索引、數據讀取操作的類型等,這篇文章主要介紹了MySQL中EXPLAIN的/基本使用及字段詳解,需要的朋友可以參考下
    2024-09-09
  • 解決MySQL數據庫中文模糊檢索問題的方法

    解決MySQL數據庫中文模糊檢索問題的方法

    解決MySQL數據庫中文模糊檢索問題的方法...
    2007-11-11
  • 刪除MySQL表中重復數據詳解

    刪除MySQL表中重復數據詳解

    這篇文章主要為大家介紹了刪除MySQL表中重復數據詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 使用Python的Django框架中的壓縮組件Django Compressor

    使用Python的Django框架中的壓縮組件Django Compressor

    這篇文章主要介紹了使用Python的Django框架中的壓縮組件Django Compressor,這個工具主要用于實現js/css的壓縮,需要的朋友可以參考下
    2015-05-05
  • mysql中整數數據類型tinyint詳解

    mysql中整數數據類型tinyint詳解

    大家好,本篇文章主要講的是mysql中整數數據類型tinyint詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評論