主頁 > 軟體設計 > 資料庫事務的四大特性,四種隔離級別,如何避免臟讀、不可重復讀、幻讀(如何加鎖)?

資料庫事務的四大特性,四種隔離級別,如何避免臟讀、不可重復讀、幻讀(如何加鎖)?

2020-11-01 09:35:26 軟體設計

目錄

第一章 資料庫基礎知識


文章目錄

  • 目錄
  • 前言
  • 資料庫事務
    • 一、定義
    • 二、要求
    • 三、影響
    • 四、特性(ACID)
      • (1)A:原子性 Atomicity
      • (2)C:一致性 Consistency
      • (3)I:隔離性 Isolation
        • 事務的隔離級別及解決方案
          • 1.未提交讀
          • 2.已提交讀
          • 3.可重復讀
          • 4.可串行化
          • 總結
      • (4)D:永久性 Durability
          • 愿你享受溫暖感受愛,sincerely,end.


前言

??認為自己大學時學得不夠深入,發現實際作業中需要用到它的地方很多,因此記下此文幫助自己梳理知識,也希望可以給需要的你提供幫助,自學之路,如有錯誤,請糾正,萬分感謝


來自筆者內心理解(以及結合相關文獻 綜合思考后)的正文:

資料庫事務

一、定義

??資料庫事務是一個不可分割的作業單位,由事務開始與事務結束之間執行的全部資料庫操作構成,這些操作要么全部執行,要么全部不執行,

二、要求

??一個資料庫事務可以包含多個查詢、修改、洗掉、插入等資料庫動作,它們要么作為一個整體完全得到確認,要么完全失敗;一個事務只能包含對一個資料庫實體的資料操作,跨多個資料庫實體需要分布式事務的支持,

三、影響

??資料庫事務會給資料庫并發操作帶來一定影響,降低系統的并發能力,

四、特性(ACID)

(1)A:原子性 Atomicity

??一個原子事務中的所有操作要么全部成功,要么全部失敗,即整個事務中的每項任務都必須正確執行,如有任一任務執行失敗,則整個事務就會被終止,此前對資料所作的任何修改都將被撤銷(回滾);如果每項任務都執行成功,事務則會被提交,是資料庫系統區別于其他一切檔案系統的重要特性之一(檔案系統出錯不可恢復),

看個小例子吧~
??假如我們需要進行轉賬服務,以下表格中的每一步都需要保證全部正確,否則需要回滾到初始狀態

First檢查活期存款余額是否高于轉賬金額
Second活期存款余額 減去 轉賬金額
Third轉賬賬戶余額 加上 轉賬金額

(2)C:一致性 Consistency

??資料庫總是從一個一致性的狀態轉換到另一個一致性的狀態,
承接上個小例子~
??我們的轉賬服務中轉出賬戶的扣除金額與轉入賬戶的轉入金額必須保持一致,

Q:誰來保證?
A:事務系統 & 應用開發人員
Q:如何保證?
A:事務系統:保證事務的原子性、隔離性和持久性
應用開發人員:保證資料庫有適當的約束,并且事務中所實作的業務邏輯要與預期現實業務情況完全一致

(3)I:隔離性 Isolation

??針對并發事務而言,事務必須在不干擾其他行程或事務的前提下獨立執行,(有級別設定)即要隔離并發運行的多個事務之間的影響,

寫在前面的兩個關鍵:共享鎖排他鎖,是實作隔離級別的兩種鎖模式,都為悲觀鎖①,
共享鎖 [S鎖_shared lock]:
?是一種讀鎖,
?當事務A對資料物件B加S鎖時,事務A可以讀B但不能修改B,其他事務也能對B加S鎖,但不能加X鎖,直到A釋放B上的S鎖,
?這保證了其他事務在A釋放B上的S鎖之前對B可讀,但不可寫,
排他鎖 [X鎖_exclusive lock]:
?是一種寫鎖,
?當事務A對臨界區B加X鎖時,事務A可以讀寫B,但其他事務不能對B加任何鎖(共享鎖,排他鎖),直到A釋放B上的X鎖,
?這保證了其他事務在A釋放B上的X鎖之前不能對B進行讀寫,
總結:
?共享鎖保證大家可以一起做只讀操作(e.g. select),不可以有人再寫入;
?排他鎖保證只能一個人去處理資料(用于資料修改,e.g. insert、update、delete),其他人不能讀寫,
?X鎖比S鎖有更高的優先級,一個X鎖請求可能會被插入到S鎖佇列的前面,但S鎖不能插入到X鎖前面,

注釋(可跳過):實作并發控制的主要手段大致可以分為樂觀并發控制和悲觀并發控制兩種,
①悲觀鎖:
??在操作資料時,認為此操作會出現資料沖突,所以在每次操作都需通過獲取鎖才能進行,
??方法 由資料庫自己實作,用的時候,直接呼叫資料庫相關陳述句就可以,
??場景 適用于沖突頻率高、重試代價大的場景,為資料處理的安全提供了保證,
??缺點 會降低并行性,需耗費較多的時間,增加產生死鎖的機會,
?樂觀鎖:
??在操作資料時,不認為此操作會出現資料沖突(不加鎖),在操作結束后再判斷是否有沖突,
??方法 需要我們自己實作,可以使用版本號等機制,資料庫不自帶,
??場景 適用于讀操作多、回應效率高的場景,可以提高程式的吞吐量,
??缺點 鎖的粒度如果掌握不好,更新失敗的概率會比較高,

事務的隔離級別及解決方案

事務隔離級別臟讀 ②不可重復讀③幻讀④
未提交讀[Read Uncommitted]允許允許允許
已提交讀[Read Committed]禁止允許允許
可重復讀[Repeatable Read]禁止禁止允許
可串行化[Serializable]禁止禁止禁止

上表中,在相同運行環境下,不同隔離級別的順序按照并發性由高到低,隔離性由低到高排序

注釋(也許看完注釋之后依舊云里霧里,that’s OK,我們還有小例子在后面):
??②臟讀:事務A讀取到了事務B沒有提交的資料
??③不可重復讀:在事務A中,兩次讀取同一資料,得到的內容不同
??④幻讀:在事務A中,相同操作讀取兩次,得到的記錄數不同

由下列例子幫助我們更好的理解事務的隔離級別:

1.未提交讀

??加鎖機制:在寫事務時加行級共享鎖,讀事務時不加鎖
??例子:事務A修改了一條記錄的內容,但是并沒有提交(commit),在隔離級別為未提交讀的情況下,事務B可以讀取到A修改后并未提交的記錄內容,(由于是共享鎖,寫事務未提交前其他事務仍然能讀)
??有何影響呢?一旦A執行回滾操作(沒有commit之前都是可以回滾的),B之前所讀取的記錄內容則為臟資料,這就造成了臟讀,[不僅臟讀無法避免,不可重復讀(下面2.已提交讀中介紹)、幻讀(下面3.可重復讀中介紹)也無法避免]

2.已提交讀

??是如何避免臟讀的呢?加鎖機制:寫事務時加行級排他鎖,事務結束才釋放;讀事務時加行級共享鎖,讀完立即釋放鎖(不等到整個事務結束后才釋放),(確保寫一行時其他事務無法讀寫此行,只有commit以后才可讀寫,讀一行時其他事務只能讀,無法寫這一行)
??例子:事務A查詢一條記錄后,并沒有結束事務A,在隔離級別為已提交讀的情況下,接著事務B修改了A剛才查詢的那條記錄(既然是已提交讀,那B修改內容后需要commit),
??有何影響呢?當A又再次查詢這條記錄時,發現與之前查詢的記錄不同(因為事務A沒結束的時候B修改了內容,導致事務A兩次讀取不一致),前后查詢的記錄不一就造成了不可重復讀,[不僅不可重復讀無法避免,幻讀(下面3.可重復讀中介紹)也無法避免]

3.可重復讀

??是如何避免不可重復讀的呢?加鎖機制:寫事務時加行級排他鎖,讀事務時加行級共享鎖,都持續到事務結束才釋放,(確保整個事務中寫就是寫,讀就是讀,整個事務讀完之后才可以寫)
??例子:事務A根據條件查詢一組記錄,之后事務B在A查詢條件的記錄范圍內插入一條記錄,
??有何影響呢?當A又使用相同的方式再次對表進行檢索時,卻發現了一條新紀錄,這個新記錄對A來說就像突然出現的一樣,這就造成了幻讀,(讀寫事務只是加了行級鎖,其他事務雖然不能修改這些行,但是能添加新行,因此出現幻讀現象)

4.可串行化

??是如何避免幻讀的呢?加鎖機制:讀事務時加表級共享鎖,寫事務時加表級排他鎖,(避免其他事務對該表的操作)

總結
事務隔離級別總結資料庫默認隔離級別
未提交讀[Read Uncommitted]事務A中的修改,即使沒有提交,其他事務也可以看得到
已提交讀[Read Committed]事務A中的修改只有提交以后才能被其它事務看到
有可能發生不可重復讀和幻讀
SQLServer , Oracle
可重復讀[Repeatable Read]事務A中看到的每條記錄的結果一致
有可能發生幻讀
MySQL
可串行化[Serializable]嚴格要求資料的一致性
靠大量加鎖實作,導致大量的鎖超時和鎖征用問題,效率低下

(4)D:永久性 Durability

??一旦事務提交成功,它對于資料的修改就會永久保存到資料庫中,此時即使系統崩潰,修改的資料也不會丟失(磁盤損壞不包括,需要靠備份等),


愿你享受溫暖感受愛,sincerely,end.

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/197910.html

標籤:其他

上一篇:ORCALE 洗掉用戶 提示無法洗掉當前連接的用戶 PLSQL

下一篇:Mysql資料庫 建庫建表增刪改查

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more