DELETE/ UPDATE/ INSERT 語句會自動加鎖

在數據庫系統中,DELETEUPDATE?和?INSERT?語句通常會自動加鎖,以確保數據的一致性和并發控制。具體的鎖類型和效果取決于數據庫的實現(如 MySQL、PostgreSQL 等)以及事務的隔離級別。以下是這些操作通常加鎖的行為和效果:


1.?DELETE 語句

  • 加鎖類型

    • 行級鎖DELETE?會對要刪除的行加鎖,通常是?排他鎖(X鎖)

    • 間隙鎖(Gap Lock):在某些隔離級別(如 MySQL 的?REPEATABLE READ),DELETE?還可能對索引間隙加鎖,防止其他事務插入新數據。

  • 效果

    • 其他事務無法對被刪除的行加鎖或修改,直到當前事務提交或回滾。

    • 如果使用了間隙鎖,其他事務也無法在鎖定范圍內插入新數據。


2.?UPDATE 語句

  • 加鎖類型

    • 行級鎖UPDATE?會對要修改的行加鎖,通常是?排他鎖(X鎖)

    • 間隙鎖(Gap Lock):在某些隔離級別下,UPDATE?也可能對索引間隙加鎖,防止其他事務插入新數據。

  • 效果

    • 其他事務無法對被修改的行加鎖或修改,直到當前事務提交或回滾。

    • 如果使用了間隙鎖,其他事務也無法在鎖定范圍內插入新數據。


3.?INSERT 語句

  • 加鎖類型

    • 行級鎖INSERT?會對新插入的行加鎖,通常是?排他鎖(X鎖)

    • 插入意向鎖(Insert Intention Lock):在插入數據時,數據庫會對插入的位置加插入意向鎖,表示有事務準備在此處插入數據。

  • 效果

    • 其他事務無法對新插入的行加鎖或修改,直到當前事務提交或回滾。

    • 插入意向鎖不會阻塞其他事務的插入操作,除非插入的位置被間隙鎖鎖定。


4.?鎖的效果與隔離級別

  • READ UNCOMMITTED

    • 不加鎖(或只加極少的鎖),允許讀取未提交的數據。

  • READ COMMITTED

    • 對修改的行加排他鎖,但不會加間隙鎖。

  • REPEATABLE READ

    • 對修改的行加排他鎖,并可能加間隙鎖,防止幻讀。

  • SERIALIZABLE

    • 對涉及的范圍加鎖,包括行鎖和間隙鎖,確保完全串行化執行。


5.?總結

操作鎖類型效果
DELETE行級鎖(X鎖)、間隙鎖阻止其他事務修改或刪除該行,可能阻止插入新數據。
UPDATE行級鎖(X鎖)、間隙鎖阻止其他事務修改該行,可能阻止插入新數據。
INSERT行級鎖(X鎖)、插入意向鎖阻止其他事務修改新插入的行,但通常不會阻塞其他插入操作(除非有間隙鎖)。

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

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

相關文章

【從零開始學習計算機科學】硬件設計與FPGA原理

硬件設計 硬件設計流程 在設計硬件電路之前,首先要把大的框架和架構要搞清楚,這要求我們搞清楚要實現什么功能,然后找找有否能實現同樣或相似功能的參考電路板(要懂得盡量利用他人的成果,越是有經驗的工程師越會懂得借鑒他人的成果)。如果你找到了的參考設計,最好還是…

SpringCloud—概述—01

一、微服務 1)單體架構 業務的所有功能實現都打包在一個 war 包或者 jar 包中,這種方式就稱為 單體架構 例如,學校中實現的博客系統,前端后端數據庫實現,都是在一個項目中 把所有模塊都寫在一個 web 項目中&#x…

C++ 學生成績管理系統

一、項目背景與核心需求 成績管理系統是高校教學管理的重要工具,本系統采用C++面向對象編程實現,主要功能模塊包括: 學生信息管理(學號/姓名/3門課程成績) 成績增刪改查(CRUD)操作 數據持久化存儲 統計分析與報表生成 用戶友好交互界面 二、系統架構設計 1. 類結構設計 …

go的grpc

GRPC介紹 目錄 單體架構微服務架構問題原始的grpc 服務端客戶端原生rpc的問題 grpc的hello world 服務端客戶端 proto文件proto語法 數據類型 基本數據類型其他數據類型 編寫風格多服務 單體架構 只能對整體擴容一榮俱榮,一損俱損代碼耦合,項目的開…

1.12.信息系統的分類【ES】

專家系統(ES)技術架構深度解析 一、ES核心定義 🧠 智能決策中樞 由三大核心能力構建的領域專家模擬系統: 存儲專家級領域知識(10^4規則量級)支持不確定性推理(置信度>85%)動態…

考研數一非數競賽復習之Stolz定理求解數列極限

在非數類大學生數學競賽中,Stolz定理作為一種強大的工具,經常被用來解決和式數列極限的問題,也被譽為離散版的’洛必達’方法,它提供了一種簡潔而有效的方法,使得原本復雜繁瑣的極限計算過程變得直觀明了。本文&#x…

html播放本地音樂

本地有多個音樂文件,想用 html 逐個播放,或循環播放,并設置初始音量。 audio 在 html 中播放音樂文件用 audio 標簽: controls 啟用控制按鈕,如進度條、播放、音量、速度等。不加不顯示任何 widget。autoplay 理應啟…

DeepSeek-Manus精品課合集【附下載】

AI消息不斷,繼DeepSeek之后,又出了一個顛覆性的AI產品Manus,號稱全球第一個通用型AI。相比與DeepSeek, Manus擁有更強的自主性和執行力。 如果說DeepDeek是一個最強大腦,那么Manus就是一個完整的人! DeepS…

MySQL復習筆記

MySQL復習筆記 1.MySQL 1.1什么是數據庫 數據庫(DB, DataBase) 概念:數據倉庫,軟件,安裝在操作系統(window、linux、mac…)之上 作用:存儲數據,管理數據 1.2 數據庫分類 關系型數據庫&#…

從源到目標:深度學習中的遷移學習與領域自適應實踐

引言:數據驅動的智能時代與遷移挑戰 在深度學習快速發展的今天,模型訓練對數據量和質量的依賴成為核心瓶頸。面對新場景時,標注數據不足、數據分布差異等問題常導致模型性能驟降。遷移學習(Transfer Learning)與領域自…

【網絡】HTTP協議、HTTPS協議

HTTP與HTTPS HTTP協議概述 HTTP(超文本傳輸協議):工作在OSI頂層應用層,用于客戶端(瀏覽器)與服務器之間的通信,B/S模式 無狀態:每次請求獨立,服務器不保存客戶端狀態(通…

Jmeter使用介紹

文章目錄 前言Jmeter簡介安裝與配置JDK安裝與配置JMeter安裝與配置 打開JMeter方式一方式二 設置Jmeter語言為中文方法一(僅一次性)方法二(永久設置成中文) Jmeter文件常用目錄 元件與組件元件組件元件的作用域元件的執行順序第一個案例添加線程組添加 H…

【NLP 32、文本匹配任務 —— 深度學習】

大劫大難以后,人不該失去銳氣,不該失去熱度,你鎮定了卻依舊燃燒,你平靜了卻依舊浩蕩,致那個從絕望中走出來的自己,共勉 —— 25.1.31 使用深度學習在文本匹配任務上主要有兩種方式:① 表示型 ②…

發展史 | 深度學習 / 云計算

注:本文為來自 csdn 不錯的“深度學習 / 云計算發展史 ” 相關文章合輯。 對原文,略作重排。 深度學習發展史(1943-2024 編年體)(The History of Deep Learning) Hefin_H 已于 2024-05-23 15:54:45 修改 …

通領科技沖刺北交所

高質量增長奔赴產業新征程 日前,通領科技已正式啟動在北交所的 IPO 進程,期望借助資本市場的力量,加速技術升級,推動全球化戰略布局。這一舉措不僅展現了中國汽車零部件企業的強大實力,也預示著行業轉型升級的新突破。…

TCP/IP 5層協議簇:網絡層(ICMP協議)

1. TCP/IP 5層協議簇 如下: 和ip協議有關的才有ip頭 2. ICMP 協議 ICMP協議沒有端口號,因為不去上層,上層協議采用端口號

RISC-V匯編學習(三)—— RV指令集

有了前兩節對于RISC-V匯編、寄存器、匯編語法等的認識,本節開始介紹RISC-V指令集和偽指令。 前面說了RISC-V的模塊化特點,是以RV32I為作為ISA的核心模塊,其他都是要基于此為基礎,可以這樣認為:RISC-V ISA 基本整數指…

C語言 —— 愿此世如黃金般輝煌 - 進制轉換與操作符詳解

目錄 1. 操作符的分類 2. ?進制和進制轉換 2.1 2進制轉10進制 2.2 10進制轉2進制 2.3 2進制轉8進制 2.4 2進制轉16進制 3. 原碼、反碼、補碼 4. 移位操作符 4.1 左移操作符 4.2 右移操作符 5. 位操作符:&、|、^、~ 5.1 & 按位與 5.2 | 按位或 …

docker1

前言 技術架構 單機架構 應用數據分離架構 應用服務集群架構 讀寫分離/主從分離架構 寫入主的時候,要同步Mysql從的數據才可以 冷熱分離架構 寫的時候要寫入主和緩存數據庫 讀的時候先去緩存看有沒有,沒有的話就去從數據庫讀數據 主要就是看這個數據是…

Spring Boot整合ArangoDB教程

精心整理了最新的面試資料和簡歷模板,有需要的可以自行獲取 點擊前往百度網盤獲取 點擊前往夸克網盤獲取 一、環境準備 JDK 17Maven 3.8Spring Boot 3.2ArangoDB 3.11(本地安裝或Docker運行) Docker啟動ArangoDB docker run -d --name ar…