數據庫四大特性與隔離級別

數據庫四大特性ACID
Atomicity (原子性) :事務(transaction)是由指邏輯上對數據的的一組操作,這組操作要么一次全部成功,如果這組操作全部失敗,是不可分割的一個工作單位。
Consistency(一致性) :在事務開始以前,被操作的數據的完整性處于一致性的狀態,事務結束后,被操作的數據的完整性也必須處于一致性狀態。
Isolation(隔離性) :事務隔離性要求系統必須保證事務不受其他并發執行的事務的影響
Durability(持久性): 一個事務一旦成功提交,它對數據庫的改變必須是永久的,即便是數據庫發生故障也應該不會對其產生任何影響。


并發事務中可能產生的問題
臟讀
兩個事務并發執行,一個事務處理過程中讀取了另一個未提交的事務中的數據
不可重復讀
兩個事務并發執行,一個事務范圍內多次查詢返回了不同的數據值,由于在查詢間隔,被另一個事務修改并提交了數據。不可重復讀和臟讀的區別是:臟讀是某一事務事務范圍內,在該事務的某次查詢中讀取了另一事務未提交的臟數據,而不可重復讀是某一事務范圍內,該事務第二次讀取數據,另一事務改變并提交了數據,導致該事務第二次讀取的數據不同于第一次讀取的數據。
虛讀(幻讀)
兩個事務并發執行,一個事務對符合某一特征的一批數據進行修改,另一事務此時插入了一條新的符合特征的數據,當進行修改的事務完成后再查看數據會發現有一條數據沒有被修改,此為幻讀。
幻讀和不可重復讀都是讀取了另一個已提交的事務(與臟讀不同),不同的是不可重復讀查詢的是同一個數據項,而幻讀針對的是一批數據整體。


mysql四個隔離級別
Read uncommitted (讀未提交)
一個事務可以讀取另一個事務未提交的數據,會導致臟讀的發生。
Read committed (讀已提交)
若有事務對數據對數據進行更新操作,讀操作要等待更新事務提交后才能讀取數據,可以解決臟讀,無法解決不可重復讀。
Repeatable read (可重復讀)
某一事務在進行讀操作時,不允許其他事務進行修改操作。此時不允許修改操作,但是可能會有插入操作,即可能會有幻讀的情況。
Serializable(序列化)
最高的事務隔離級別,在該級別下事務串行化執行,有效避免臟讀,不可重復讀,幻讀,但是對數據庫性能影響比較大。

轉載于:https://www.cnblogs.com/helloz/p/8024880.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251345.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251345.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251345.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

重學《JavaScript 高級程序設計》筆記 第6章對象

第6章 面向對象的程序設計 ECMAScript中沒有類的概念; 1.創建對象-歷史 1.1 創建實例,添加方法和屬性 → 對象字面量 缺點: 使用同一接口創建很多對象,產生大量重復代碼 var person new Object() person.name "Y" pe…

Java-reflect(反射)初步理解_1

27.01_反射(類的加載概述和加載時機) A:類的加載概述 當程序要使用某個類時,如果該類還未被加載到內存中,則系統會通過加載,連接,初始化三步來實現對這個類進行初始化。加載 就是指將class文件讀入內存,并為之創建一個…

javascrip --- 構造函數的繼承

兩點需要注意的. 第一是在構造函數聲明時,會同時創建一個該構造函數的原型對象,而該原型對象是繼承自Object的原型對象 // 聲明一個構造函數Rectengle function Rectangle(length, width) {this.length length;this.width width; }// 即:看見function 后面函數名是大寫,一般…

Ruby實例方法和類方法的簡寫

創建: 2017/12/12 類方法 Sample.func實例方法 Sample#func轉載于:https://www.cnblogs.com/lancgg/p/8281677.html

《JavaScript 高級程序設計》筆記 第7章及以后

第7章 函數表達式 匿名函數的name屬性是空字符串;閉包是函數:閉包是有權訪問另一個函數作用域中變量的函數;(P181 副作用,解釋了點擊li彈出循環最后值的原因)當某個函數第一次被調用時,會創建一個執行環境及相應作用域鏈&#xf…

[樹形dp] Jzoj P1046 尋寶之旅

Description 探險隊長凱因意外的弄到了一份黑暗森林的藏寶圖,于是,探險隊一行人便踏上了尋寶之旅,去尋找傳說中的寶藏。藏寶點分布在黑暗森林的各處,每個點有一個值,表示藏寶的價值。它們之間由一些小路相連&#xff0…

javascript --- 使用語法糖class定義函數

本文討論的是通過class聲明的函數,有什么特點,或者說是指向了哪里. class A() {} // A是一個類// 要看class聲明的函數指向哪里,只需將其[[Prototype]]屬性打印到控制臺,下面看看A和它的原型對象的指向 // 注:[[Prototype]]屬性通過__proto__訪問 console.log(A.__proto__…

前端知識點整理收集(不定時更新~)二

目錄 require() 加載文件機制 線程和進程 線程 單線程 Nodejs的線程與進程 網絡模型 初識 TCP 協議 三次握手 I/O I/O 先修知識 阻塞與非阻塞 I/O 同步與異步 I/O Git 基礎命令 分支操作 修改遠程倉庫地址 遠程分支獲取最新的版本到本地 拉取遠程倉庫指定分支…

SpringBoot零基礎入門指南--搭建Springboot然后能夠在瀏覽器返回數據

File->new Project 修改默認包名,根據自己的喜好修改 選擇初始化需要導入的包,盡量不要一開始就導入很多,特別是數據庫,不然啟動可能會有問題,創建好的目錄如下: 配置文件寫在application.properties下&…

JavaScript算法相關

1. 排序 1.1.冒泡排序 每一輪比較&#xff0c;從左至右交換相鄰&#xff0c;每輪結束&#xff0c;最后一個為最大下一輪&#xff0c;需要比較的個數 - 1 j < len - i (范圍動態縮小)共 len - 1 輪比較 function bubbleSort(arr) {var len arr.length;for (var i 1; i &…

javascript --- 編程風格

字符串 const a foobar; const b foo${a}bar; // 此處是反引號(tab鍵上) const c foobar;解構賦值 const [first, second] arr;function getFullName({ firstName, lastName }) { }function processInput(input) {return { left, right, top, bottom }; } const { left…

$ - 字符串內插

$ 特殊字符將字符串文本標識為內插字符串。 內插字符串是可能包含內插表達式的字符串文本。 將內插字符串解析為結果字符串時&#xff0c;帶有內插表達式的項會替換為表達式結果的字符串表示形式。 此功能在 C# 6 及該語言的更高版本中可用。 與使用字符串復合格式設置功能創建…

數據結構基礎知識

排序 參考&#xff1a;https://www.bilibili.com/video/av38482633/?spm_id_fromtrigger_reload 目錄 排序 插入排序 直接插入排序 折半排序 希爾排序 ? 交換排序 冒泡排序 快速排序 選擇排序 堆排序 流量單位計算 什么是計數排序 復雜度分析&#xff1a; 什…

linux中安裝軟件,查看、卸載已安裝軟件方法

各種主流Linux發行版都采用了某種形式的包管理系統&#xff08;PMS&#xff09;來控制軟件和庫的安裝。 軟件包存儲在服務器上&#xff0c;可以利用本地Linux系統上的PMS工具通過互聯網訪問。這些服務器稱為倉庫。 由于Linux發行版眾多,目前還沒有統一的PMS標準工具。 這里分別…

html5 --- 使用javascript腳本控制媒體播放

H5中的標簽(<audio…/> 和 <video…/>)對于JS中的HTMLAudioElement對象和HTMLVideoElement對象 對象有以下幾個方法: play(): 播放 pause(): 暫停播放 load(): 重新裝載音頻、視頻 canPlayType(type): 判斷該元素可播放type類型的音頻、視頻 下面是一個簡單的音樂…

在js中if條件為null/undefined/0/NaN/表達式時,統統被解釋為false,此外均為true

Boolean 表達式 一個值為 true 或者 false 的表達式。如果需要&#xff0c;非 Boolean 表達式也可以被轉換為 Boolean 值&#xff0c;但是要遵循下列規則&#xff1a; 所有的對象都被當作 true。當且僅當字符串為空時&#xff0c;該字符串被當作 false。null 和 undefined 被當…

ES6專題——整理自阮一峰老師的ECMAScript 6入門

這里我僅僅是記錄了那些我認為值得注意的ES6知識點&#xff0c;詳細版請挪步https://es6.ruanyifeng.com/#docs/let let和const命令 let聲明的變量只在它所在的代碼塊有效。 var a []; for (let i 0; i < 10; i) {a[i] function () {console.log(i);}; } a[6](); // 6 …

開發測試比

1.服務器已經開啟了CORS跨域支持 瀏覽器有同源策略限制&#xff1a;協議、域名、端口號其中無法向非同源地址發送ajax請求 跨域解決方法&#xff1a;JSONP&#xff08;只支持get不支持post&#xff09;&#xff0c;不是ajax 凡是有src屬性的標簽都有跨域能力 前端定義一個處理…

map函數用法詳解

map函數是Python內置的高階函數&#xff0c;它是一個典型的函數式編程例子。它的參數為: 一個函數function、一個或多個sequence。通過把函數function依次作用在sequence的每個元素上&#xff0c;得到一個新的sequence并返回。注意&#xff1a;map函數不改變原有的sequence&…

2018暑假集訓測試六總結

拿到試題沒幾分鐘&#xff0c;就有人說會做T1QAQ。第一題感覺似曾相識&#xff0c;其實不同。梳理出本質后發現有兩個限制&#xff0c;便想用枚舉遞推來快速求解&#xff0c;發現要么是不會推&#xff0c;要么是時空超限&#xff0c;不會優化。期間也想過通過離線做&#xff0c…