MySQL-事務篇

文章目錄

  • 何為事務?
  • 什么是事務的ACID特性?
  • 并發事務帶來了哪些問題?
  • 不可重復讀和幻讀有什么區別?
  • 并發事務的控制方式有哪些?
  • SQL標準定義了哪些事務隔離級別?
  • MYSQL的隔離級別是基于鎖實現的嗎?

何為事務?

事務是邏輯上的一組操作,要么都執行,要么都不執行

什么是事務的ACID特性?

  1. A(原子性):事務是最小的執行單位,不允許分割
  2. C(一致性):執行數據前后,數據保持一致
  3. I(隔離性):并發訪問數據庫時,一個用戶的事務不被其他的事務所干擾,各并發事務之間數據庫是獨立的
  4. D(持久性):一個事務被提交后,它對數據庫的改變是持久的,即使數據庫發生故障也不應該對其有任何影響

注意:A,I,D是手段,C是目的

并發事務帶來了哪些問題?

多個事務并發執行,多個用戶對同一用戶進行操作,可能會出現以下問題
臟讀
一個事務修改了數據,但未提交,此時另一個事務讀取了這個還未提交的事務,但是第一個事務突然回滾,導致數據并未提交到數據庫,這里第二個事務讀取到的就是臟數據

丟失修改
一個事務讀取到一個數據時,另一個事務也訪問了該數據,第一個事務對數據進行修改,另一個事務又修改了這個數據,這樣第一個事務內的修改結果就被丟失

不可重復讀
一個事務內多次讀同一個數據,期間另外一個事務對數據進行修改,使得第一個事務兩次讀到的內容不一致

幻讀
一個事務讀取了數據,接著另外的并發事務插入了一些數據,則前一個事務再次讀取數據時,發現多出了一些記錄,像幻覺一樣!

不可重復讀和幻讀有什么區別?

不可重復讀重點是多次讀取數據發現其中某些記錄的值被修改
幻讀重點是多次讀取數據發現查到的記錄增加
幻讀可以看成是不可重復讀的一種特殊情況,區分是因為解決兩者的方案不一樣

并發事務的控制方式有哪些?

鎖和MVCC (todo 完善)

SQL標準定義了哪些事務隔離級別?

  • READ-UNCOMMITTED(讀取未提交)
  • READ-COMMITTED(讀取已提交)
  • **REPEATABLE-READ(可重復讀) : **InnoDB存儲引擎支持的默認隔離級別
  • SERIALIZABLE(可串行化)
隔離級別臟讀不可重復讀幻讀
READ-UNCOMMITTED
READ-COMMITTED×
REPEATABLE-READ××
SERIALIZABLE×××

MYSQL的隔離級別是基于鎖實現的嗎?

是基于鎖和MVCC機制共同實現的
SERIALIZABLE 是通過鎖來實現的,READ-COMMITTED和REPEATABLE-READ是基于MVCC實現的

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

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

相關文章

微服務- protobuf 安裝

這里寫自定義目錄標題 1:下載鏈接2 :下載對應的包3:解壓到目錄4:設置環境變量5: 查看版本 1:下載鏈接 https://github.com/protocolbuffers/protobuf/releases 2 :下載對應的包 3:解壓到目錄 4&…

從RTTR談Reflection機制

雖然C11引入了RTTI、Metaprogramming 等技術,但C在Reflection編程方面依舊功能有限。在社區上,RTTR則提供了一套C編寫的反射庫,補充了C在Reflection方面的缺陷。 零、環境 操作系統Windows 11Visual StudioVisual Studio Community 2022 CMa…

git 命令 - rebase

簡介 git rebase 是一個用于重新應用一系列提交到另一個基礎的 Git 命令。 它可以用來整合來自不同分支的更改,同時保持項目歷史的整潔。 操作流程 開始變基: 要開始一個變基操作,你需要指定一個基礎分支。通常,這個基礎分支是…

2024.05.14 Diffusion 代碼學習筆記

配環境 我個人用的是Geowizard的環境:https://github.com/fuxiao0719/GeoWizard。 出于方便考慮,用的pytorch官方的docker容器,因此python版本(3.10)和原作者(3.9)不同,其余都是一…

一文說通用戶故事點數是什么?

一文說通用戶故事點數是什么? 第26期:一文說通用戶故事點數是什么? 用戶故事點數是一種采用相對估算法進行估算的一種工具,一般采用斐波那契數列表征用戶故事里說的大小,采用0 1 2 3 5 8 13這樣的一些數字來表征用戶…

【漏洞復現】Secnet-智能路由系統 actpt_5g.data信息泄露

0x01 產品簡介 Secnet安網智能AC管理系統是廣州安網通信技術有限公司(簡稱“安網通信”)的無線AP管理系統 0x02 漏洞描述 Secnet智能路由系統 acipt 5g.data 接口存在信息泄露漏洞,未經身份驗證的遠程攻擊者可以利用此漏洞獲取系統賬戶名密碼等重要憑據&#xff…

全流程TOUGH系列軟件實踐技術應用

TOUGH系列軟件是由美國勞倫斯伯克利實驗室開發的,旨在解決非飽和帶中地下水、熱運移的通用模擬軟件。和傳統地下水模擬軟件Feflow和Modflow不同,TOUGH系列軟件采用模塊化設計和有限積分差網格剖分方法,通過配合不同狀態方程(EOS模…

永磁同步電機的脈振高頻注入無速度傳感器simulink仿真模型

整理了永磁同步電機的脈振高頻注入無速度傳感器simulink仿真模型,該模型高頻注入仿真pmsm,無感控制,解決0速轉矩輸出問題,插入式永磁同步電機,凸極,高頻注入。MATLAB/simulink仿真,適合研究學習…

騰訊開源混元DiT文生圖模型,消費級單卡可推理

節前,我們組織了一場算法崗技術&面試討論會,邀請了一些互聯網大廠朋友、今年參加社招和校招面試的同學。 針對大模型技術趨勢、大模型落地項目經驗分享、新手如何入門算法崗、該如何準備面試攻略、面試常考點等熱門話題進行了深入的討論。 總結鏈接…

第七十八章 IIS 技術說明

文章目錄 第七十八章 IIS 技術說明IIS 應用程序池和Web Gardens應用程序池Web Gardens 應用程序池、Web花園和CSP 第七十八章 IIS 技術說明 對于那些有興趣使用 IIS 的人,此頁面介紹了應用程序池、網絡花園和位數。 IIS 應用程序池和Web Gardens 應用程序池 應用…

【AI+漫畫】程序員小李解決疑難雜癥BUG的日常

周末花了點時間制作的AI漫畫。 感慨一句,程序人生, 相伴隨行。 原文鏈接:【AI漫畫】程序員小李解決疑難雜癥BUG的日常

一物一碼數字化營銷進軍調味品行業,五豐黎紅“星廚俱樂部”火啦!

近日,由五豐黎紅聯合納寶科技精心打造的小程序“星廚俱樂部”火啦!一經上線就吸引了大量用戶注冊和參與,可以說取得了非常成功的市場反饋,那究竟是一個什么樣的小程序,竟然有這么大的吸引力呢? 介紹小程序之…

武漢星起航:中國賣家借力亞馬遜跨境電商平臺,拓展全球銷售市場

隨著互聯網技術的飛速發展,跨境電商已成為連接全球消費者與賣家的重要橋梁。作為全球領先的跨境電商平臺,亞馬遜憑借其強大的品牌影響力、豐富的商品資源和高效的物流體系,為全球消費者提供了一個便捷、安全的購物環境。在這個平臺上&#xf…

連鎖收銀系統如何助力實體門店私域運營

作為實體門店,私域運營是提升客戶黏性和增加復購率的重要策略之一。而連鎖收銀系統在私域運營中扮演了關鍵的角色,它不僅可以幫助門店管理客戶信息和消費記錄,還能夠通過數據分析和營銷功能提供個性化的服務和推廣活動。下面看看連鎖收銀系統…

能源能耗管理系統

隨著全球對綠色、低碳、可持續發展理念的深入認識,企業對于能源的管理和節能降耗的需求日益迫切。在這一背景下,HiWoo Cloud平臺憑借其先進的能源能耗管理系統,為企業提供了一套高效、智能的解決方案,助力企業實現綠色節能&#x…

InfiniGate自研網關實現五

17.核心通信組件管理和處理服務映射 引入模塊api-gateway-core 到 api-gateway-assist 中進行創建和使用,并拉取自注冊中心的映射信息注冊到本地的網關通信組件中。 第17節是在第15節的基礎上繼續完善服務發現的相關功能,把從注冊中心拉取的網關映射信…

GPT3.5與GPT4.0的差別對比

隨著人工智能技術的飛速發展,GPT系列模型已成為自然語言處理(NLP)領域的翹楚。GPT3.5和GPT4.0作為這一系列的最新成員,各自在性能和應用上都有所突破。 GPT4.0預計將擁有數千億個參數,與前代GPT3.5相比,模…

ZYNQ之嵌入式驅動開發——字符設備驅動

文章目錄 Linux驅動程序分類Linux應用程序和驅動程序的關系簡單的測試驅動程序在petalinux中添加LED驅動新字符設備驅動 Linux驅動程序分類 驅動程序分為字符設備驅動、塊設備驅動和網絡設備驅動。 字符設備是按字節訪問的設備,比如以一個字節收發數據的串口&#…

軟信天成:業務流程管理驅動企業數字化轉型

近日,在國家發展改革委辦公廳、國家數據局綜合司聯合印發的《數字經濟2024年工作要點》中,明確強調了本年度大力推進重點領域數字化轉型,營造數字化轉型生態的戰略舉措,標志著國家對于企業數字化轉型的高度重視與積極倡導。 企業…

dubbo復習:(3) 服務超時時間配置

在dubbo admin中 可以進行類似如下配置 configVersion: v2.7 enabled: true configs:- side: consumeraddresses:- 0.0.0.0parameters:timeout: 55這樣配置之后,當服務端響應超過55毫秒時,在服務消費者的控制臺就會看到超時信息