浅析MySQL事务锁

在 MySQL 中,事务锁是用于确保数据一致性和并发控制的重要机制。事务锁可以帮助防止多个事务同时修改同一数据,从而避免数据不一致和脏读、不可重复读、幻读等问题。
以下是 MySQL 事务锁的关键点总结:

  1. 事务锁:用于确保数据一致性和并发控制。
  2. 锁的类型
    • 行级锁:InnoDB,粒度细,性能高。
    • 表级锁:MyISAM,粒度粗,性能低。
  3. 锁的获取与释放:通过 SELECT ... LOCK IN SHARE MODESELECT ... FOR UPDATE 获取锁,事务提交或回滚时释放锁。
  4. 常见锁类型
    • 共享锁(S 锁):允许多个事务读取,阻止修改。
    • 排他锁(X 锁):阻止其他事务读取和修改。
    • 意向锁(IS, IX, SIX 锁):表示事务的意图。
    • 间隙锁(Gap Locks):防止幻读。
    • 记录锁(Record Locks):锁定具体的行。
    • 间隙加记录锁(Next-Key Locks):锁定索引记录及其前后间隙。
  5. 事务隔离级别:影响锁的使用和数据一致性。
  6. 锁冲突:了解锁冲突和死锁,优化事务逻辑。
  7. 锁的优化:减少锁持有时间,选择合适的隔离级别,使用索引,避免死锁。
  8. 监控与诊断:使用 SHOW ENGINE INNODB STATUSinformation_schema 查看锁信息。

详述:

文章目录

      • **1. 事务锁概述**
        • **1.1 什么是事务锁?**
        • **1.2 事务隔离级别**
      • **2. 锁的类型**
        • **2.1 行级锁(Row-Level Locks)**
        • **2.2 表级锁(Table-Level Locks)**
      • **3. 锁的获取与释放**
        • **3.1 获取锁**
        • **3.2 释放锁**
      • **4. 常见锁类型**
        • **4.1 共享锁(Shared Lock, S 锁)**
        • **4.2 排他锁(Exclusive Lock, X 锁)**
        • **4.3 意向锁(Intention Locks)**
        • **4.4 间隙锁(Gap Locks)**
        • **4.5 记录锁(Record Locks)**
        • **4.6 间隙加记录锁(Next-Key Locks)**
      • **5. 示例**
        • **5.1 使用共享锁(S 锁)**
        • **5.2 使用排他锁(X 锁)**
        • **5.3 使用间隙锁(Gap Locks)**
        • **5.4 使用记录锁(Record Locks)**
        • **5.5 使用间隙加记录锁(Next-Key Locks)**
      • **6. 锁冲突**
        • **6.1 锁冲突示例**
        • **6.2 死锁**
      • **7. 事务隔离级别与锁的关系**
        • **7.1 读未提交(Read Uncommitted)**
        • **7.2 读已提交(Read Committed)**
        • **7.3 可重复读(Repeatable Read)**
        • **7.4 串行化(Serializable)**
      • **8. 锁的优化**
        • **8.1 减少锁持有时间**
        • **8.2 选择合适的隔离级别**
        • **8.3 使用索引**
        • **8.4 避免死锁**
      • **9. 监控与诊断**
        • **9.1 查看锁信息**
        • **9.2 使用 `information_schema`**
      • **10. 示例代码**
        • **10.1 创建表**
        • **10.2 使用共享锁**
        • **10.3 使用排他锁**

1. 事务锁概述

1.1 什么是事务锁?
  • 事务锁:在事务执行期间,数据库系统使用锁来控制对数据的访问,确保事务的隔离性和一致性。
  • 目的
    • 防止脏读:一个事务读取了另一个事务未提交的数据。
    • 防止不可重复读:一个事务多次读取同一数据时,数据被其他事务修改。
    • 防止幻读:一个事务在两次查询之间,其他事务插入了新的数据行。
1.2 事务隔离级别
  • 读未提交(Read Uncommitted):最低的隔离级别,允许脏读。
  • 读已提交(Read Committed):不允许脏读,但允许不可重复读和幻读。
  • 可重复读(Repeatable Read):默认隔离级别,不允许脏读和不可重复读,但允许幻读。
  • 串行化(Serializable):最高的隔离级别,完全串行化事务,不允许脏读、不可重复读和幻读。

2. 锁的类型

2.1 行级锁(Row-Level Locks)
  • 适用存储引擎:InnoDB
  • 特点
    • 粒度细:只锁定特定的行,减少锁冲突。
    • 性能高:适用于高并发场景。
  • 类型
    • 共享锁(Shared Lock, S 锁):允许多个事务同时读取同一行,但阻止其他事务修改该行。
    • 排他锁(Exclusive Lock, X 锁):阻止其他事务读取和修改该行。
2.2 表级锁(Table-Level Locks)
  • 适用存储引擎:MyISAM、InnoDB(某些情况下)
  • 特点
    • 粒度粗:锁定整个表,可能导致高并发下的性能瓶颈。
    • 简单:实现简单,但可能导致锁冲突。
  • 类型
    • 读锁(Read Lock):允许多个事务同时读取表,但阻止其他事务写入表。
    • 写锁(Write Lock):阻止其他事务读取和写入表。

3. 锁的获取与释放

3.1 获取锁
  • 共享锁:使用 SELECT ... LOCK IN SHARE MODE
    SELECT * FROM table_name WHERE id = 1 LOCK IN SHARE MODE;
    
  • 排他锁:使用 SELECT ... FOR UPDATE
    SELECT * FROM table_name WHERE id = 1 FOR UPDATE;
    
3.2 释放锁
  • 自动释放:事务提交(COMMIT)或回滚(ROLLBACK)时自动释放锁。
  • 显式释放:某些情况下可以通过特定的 SQL 语句释放锁。

4. 常见锁类型

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902001.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue3 文件下载(excel/rar/zip)

安装axios npm install axios 在项目中引入 import axios from axios; 1、get接口excel文件下载 const file_key ref() const downLoadExcel (value:any) > {//file_key.value value axios({method: "get",url: "/api/da/download_excel/",//url:…

RT-Thread RTThread studio 初使用

RT-Thread Studio 下载 https://www.rt-thread.org/studio.html 安装使用 https://bbs.elecfans.com/jishu_2425653_1_1.html 4 编译问题解决 问题一:error: unknown type name clock_t 具体的类型值是在sys/_types.h中定义的,需要包含sys/_types.h 这个…

汉诺塔专题:P1760 通天之汉诺塔 题解 + Problem D: 汉诺塔 题解

1. P1760 通天之汉诺塔 题解 题目背景 直达通天路小A历险记第四篇 题目描述 在你的帮助下,小 A 成功收集到了宝贵的数据,他终于来到了传说中连接通天路的通天山。但是这距离通天路仍然有一段距离,但是小 A 突然发现他没有地图&#xff0…

探索 HumanoidBench:类人机器人学习的新平台

在科技飞速发展的当下,类人机器人逐渐走进我们的视野,它们有着和人类相似的外形,看起来能像人类一样在各种环境里完成复杂任务,潜力巨大。但实际上,让类人机器人真正发挥出实力,还面临着重重挑战。 这篇文…

数据结构中的宝藏秘籍之广义表

广义表,也被称作列表(Lists),是一种递归的数据结构。它就像一个神秘的盒子,既可以装着单个元素(原子),也可以嵌套着其他的盒子(子列表)。比如广义表 (a (b c)…

【jenkins】首次配置jenkins

第一步,输入管理员密码 cat /var/jenkins_home/secrets/initialAdminPassword第二步,点击安装推荐的插件 第三步,创建管理员用户 第四步,返回实例 第五步, 升级jenkins 第六步, 修复提示 第七步&#xff0c…

Android studio—socketIO库return与emit的使用

文章目录 一、Socket.IO库简单使用说明1. 后端 Flask Flask-SocketIO2. Android 客户端集成 Socket.IO3. 布局文件注意事项 二、接受服务器消息的二种方法1. 客户端接收通过 emit 发送的消息功能使用场景后端代码(Flask-SocketIO)客户端代码&#xff08…

用Prompt 技术【提示词】打造自己的大语言智能体

机器如何按照人类的指令执行任务的探索 机器需具备理解任务叙述的能力,以便能够按照人类的指令执行任务,为机器提供一些范例作为参考,使其能够理解该执行的任务类型。这样的学习方式称为“Instruction learning”,透过精心设计的…

Node.js 数据库 事务 项目示例

1、参考:JavaScript语言的事务管理_js 函数 事务性-CSDN博客 或者百度搜索:Nodejs控制事务, 2、实践 2.1、对于MySQL或MariaDB,你可以使用mysql或mysql2库,并结合Promise或async/await语法来控制事务。 使用 mysql2…

【Mamba】MambaVision论文阅读

文章目录 MambaVision一、研究背景(一)Transformer vs Mamba​(二)Mamba in CV​ 二、相关工作​(一)Transformer 在计算机视觉领域的进展​(二)Mamba 在计算机视觉领域的探索​ 三、…

前端面试宝典---原型链

引言----感谢大佬的讲解 大佬链接 原型链示意图 原型链问题中需要记住一句话:一切变量和函数都可以并且只能通过__proto__去找它所在原型链上的属性与方法 原型链需要注意的点 看上图可以发现 函数(构造函数)也可以通过__proto__去找到原…

C语言---FILE结构体

一、FILE 结构体的本质与定义 基本概念 FILE 是 C 语言标准库中用于封装文件操作的结构体类型&#xff0c;定义于 <stdio.h> 中。它代表一个“文件流”&#xff0c;可以是磁盘文件、标准输入输出&#xff08;stdin/stdout/stderr&#xff09;或其他输入输出设备。 实现特…

基于大模型的直肠息肉诊疗全流程风险预测与方案优化研究报告

目录 一、引言 1.1 研究背景与意义 1.2 研究目的与创新点 二、大模型技术概述 2.1 大模型原理简介 2.2 大模型在医疗领域应用现状 三、直肠息肉术前预测与准备 3.1 基于大模型的术前风险预测 3.1.1 息肉性质预测 3.1.2 手术难度预测 3.2 基于预测结果的术前准备 3.…

华为OD机试真题——MELON的难题(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现

2025 A卷 200分 题型 本文涵盖详细的问题分析、解题思路、代码实现、代码详解、测试用例以及综合分析&#xff1b; 并提供Java、python、JavaScript、C、C语言、GO六种语言的最佳实现方式&#xff01; 2025华为OD真题目录全流程解析/备考攻略/经验分享 华为OD机试真题《MELON的…

AI数据分析与BI可视化结合:解锁企业决策新境界

大家好&#xff0c;今天我们来聊聊一个前沿而热门的话题——AI数据分析与BI可视化结合&#xff0c;如何携手推动企业决策迈向新高度。在数据爆炸的时代&#xff0c;企业如何高效利用这些数据&#xff0c;成为制胜的关键。AI数据分析与BI可视化的结合&#xff0c;正是解锁这一潜…

克服储能领域的数据处理瓶颈及AI拓展

对于储能研究人员来说&#xff0c;日常工作中经常围绕着一项核心但有时令人沮丧的任务&#xff1a;处理实验数据。从电池循环仪的嗡嗡声到包含电压和电流读数的大量电子表格&#xff0c;研究人员的大量时间都花在了提取有意义的见解上。长期以来&#xff0c;该领域一直受到对专…

【SpringBoot+Vue自学笔记】002 SpringBoot快速上手

跟着这位老师学习的&#xff1a;https://www.bilibili.com/video/BV1nV4y1s7ZN?vd_sourceaf46ae3e8740f44ad87ced5536fc1a45 最好和老师的idea版本完全一致&#xff01;截至本文写的当日最新的idea好像默认jdk17&#xff0c;配置时遇到很多bug。 &#x1f33f; Spring Boot&a…

SpringAI+DeepSeek大模型应用开发——2 大模型应用开发架构

目录 2.大模型开发 2.1 模型部署 2.1.1 云服务-开放大模型API 2.1.2 本地部署 搜索模型 运行大模型 2.2 调用大模型 接口说明 提示词角色 ​编辑 会话记忆问题 2.3 大模型应用开发架构 2.3.1 技术架构 纯Prompt模式 FunctionCalling RAG检索增强 Fine-tuning …

蓝桥杯12. 日期问题

日期问题 原题目链接 题目描述 小明正在整理一批历史文献。这些历史文献中出现了很多日期。 小明知道这些日期都在 1960 年 1 月 1 日 至 2059 年 12 月 31 日 之间。 令小明头疼的是&#xff0c;这些日期采用的格式非常不统一&#xff1a; 有的采用 年/月/日有的采用 月…

STM32使用rand()生成随机数并显示波形

一、随机数生成 1、加入头文件&#xff1a;#include "stdlib.h" 2、定义一个用作生成随机数种子的变量并加入到滴答定时器中不断自增&#xff1a;uint32_t run_times 0; 3、设置种子&#xff1a;srand(run_times);//每次生成随机数前调用一次为佳 4、生成一个随…