当前位置: 首页 > news >正文

mysql锁分类大全

前言

为什么会出现锁

MySQL中的锁是为了保证并发操作的正确性和一致性而存在的。

当多个用户同时对同一份数据进行操作时,如果不加控制地进行读写操作,就可能导致数据不一致的问题。例如,当多个用户同时对同一行数据进行写操作时,就可能出现数据被覆盖的情况。这时,通过使用锁,可以控制用户对数据的访问,保证同一时间只有一个用户对数据进行修改或者读取操作,从而避免数据的不一致。

模式分类

乐观锁(Optimistic Locking)

是什么

乐观锁并不是锁,而是锁的设计思想。认为对同一数据的并发操作不会总发生,属于小概率事件,不用每次都对数据上锁,而是在更新时检查数据版本(通常是一个版本号或时间戳),如果版本号或时间戳与之前的一致,则认为数据没有被修改,可以更新;如果不一致,则认为数据已经被修改,更新操作失败。这种方式不会阻塞其他访问请求,但是如果冲突频繁发生,则需要重试更新操作,可能会增加系统的复杂度。

优缺点

  • 优点:

乐观并发控制没有实际加锁,所以没有额外开销,也不错出现死锁问题,适用于读多写少的并发场景,因为没有额外开销,所以能极大提高数据库的性能。。

  • 缺点:

乐观并发控制不适合于写多读少的并发场景下,因为会出现很多的写冲突,导致数据写入要多次等待重试,在这种情况下,其开销实际上是比悲观锁更高的。而且乐观锁的业务逻辑比悲观锁要更为复杂,业务逻辑上要考虑到失败,等待重试的情况,而且也无法避免其他第三方系统对数据库的直接修改的情况。

怎么玩

悲观锁(Pessimistic Locking)

是什么

悲观锁也是一种思想,对数据被其他事务的修改持保守态度,每次更新数据钱都会添加锁,会通过数据库自身的锁机制来实现,从而保证数据操作的排它性。

优缺点

  • 优点:

悲观并发控制采取的是保守策略:“先取锁,成功了才访问数据”,这保证了数据获取和修改都是有序进行的,因此适合在写多读少的环境中使用。当然使用悲观锁无法维持非常高的性能,但是在乐观锁也无法提供更好的性能前提下,悲观锁却可以做到保证数据的安全性。

  • 缺点:

由于需要加锁,而且可能面临锁冲突甚至死锁的问题,悲观并发控制增加了系统的额外开销,降低了系统的效率,同时也会降低了系统的并行性。

怎么玩

按颗粒度分类

InnoDBMyISAMBDB
表锁truetruetrue
页锁falsefalsetrue
行锁truefalsefalse

全局锁(Global Lock)

是什么

全局锁就是对整个数据库实例加锁,加锁后的整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将被阻塞。

优缺点

  • 优点:
  1. 简单:全局锁是 MySQL 内部实现的一种简单锁机制,可以很容易地使用。

  2. 稳定:全局锁是最稳定的锁,能够保证操作的一致性和安全性。

  3. 效率高:当需要执行全局操作时,全局锁是最高效的锁机制。它可以在很短的时间内锁定整个数据库,确保操作的原子性。

  4. 灵活:MySQL 全局锁还可以用于备份和恢复数据库、进行主从同步等。

  5. 安全:全局锁可以保证数据的完整性和一致性,防止数据丢失和损坏。

  • 缺点:

它会对数据库的并发性能产生很大的影响,并且会导致其他用户的请求被阻塞。因此,在使用全局锁时需要慎重考虑其优缺点,确保操作的安全和效率。

怎么玩

加锁

flush tables with read lock

解锁

unlock tables

表级锁(Table Lock)

是什么

表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分 MySQL 引擎支持;

优缺点

  • 优点:

开销小,加锁快;不会出现死锁;

  • 缺点:

锁定粒度大,发出锁冲突的概率最高,并发度最低。

怎么玩

加表读锁或叫共享锁

lock tables t_student read;

加表写锁或叫独占锁

lock tables t_stuent write;

解锁

unlock tables

页级锁(Page Lock)

是什么

锁定表中某些行集合(称做页),被锁定的行只对锁定最初的线程是可行。如果另外一个线程想要向这些行写数据,它必须等到锁被释放。不过其他页的行仍然可以使用。在MySQL5.1之前BDB引擎默认页级锁,之后被弃用。

优缺点

  • 优点:
  1. 提高并发性能:页级锁的粒度比表级锁小,可以让更多的并发事务同时访问不同的数据页,从而提高了并发性能。
  2. 减少锁冲突:页级锁只锁定需要修改的数据页,减少了锁冲突的可能性,降低了锁等待时间和死锁的风险。
  3. 提高精度:由于锁的粒度更细,所以事务只需要锁定需要修改的数据页,而不是整个表,这提高了锁的精度,减少了不必要的锁。
  • 缺点:
  1. 内存开销较大:MySQL在使用页级锁时需要维护大量的锁信息,这些信息需要占用内存,如果数据表很大,锁信息的存储可能会占用较多的内存。
  2. 锁定时间较长:由于页级锁只锁定需要修改的数据页,而不是整个表,因此锁定的时间会相对较长,尤其是在对大量数据进行操作时,这会导致并发性能下降。
  3. 容易造成页分裂:页级锁需要将表分成若干页,如果频繁对数据进行修改,会导致数据页不断增加,从而容易造成页分裂,进一步增加了内存的占用。

怎么玩

SELECT * FROM table_name WHERE id BETWEEN 1 AND 100 FOR UPDATE;

行级锁(Row Lock)

是什么

基于索引数据结构实现,是 MySQL 中锁定粒度最细的一种锁,只有线程当前使用的行被锁定,其他行对于其他线程都是可用的;InnoDB引擎默认的锁级别。

注意:

InnoDB的行锁是针对索引加的锁,不是针对记录加的锁。并且该索引不能失效,否则都会从行锁升级为表锁。

优缺点

  • 优点:

发生锁冲突几率低,并发高

  • 缺点:

开销大,加锁慢;会出现死锁的情况;

怎么玩

  • 记录锁(Record Locks)

几对某条记录加锁

update user set age=10 where id=1
  • 间隙锁(Gap Locks)

即对某个范围加锁,但是不包含范围的临界数据

update user set age=10 where id>10 and id<10
  • 临键锁(Next-Key Locks)

又记录锁和间隙锁组成,既包含记录本身又包含范围,左开右闭区间

update user set age=10 where id>10 and id<=10

属性分类

共享锁/读锁(Shared Lock/S锁)

是什么

是用于读取数据时使用的一种锁。当一个事务对一个数据对象加上共享锁时,其他事务也可以对该数据对象加上共享锁,但是不能对其加上排它锁。也就是说,其他事务可远观而不可亵玩焉。

优缺点

  • 优点:

因为共享锁可以让多个事务在同一时间访问同一资源,所以在读多写少的情况下,共享锁能够提高系统的并发性能和吞吐量。

  • 缺点:
  1. 共享锁对于写操作是阻塞的,即如果一个事务已经持有了共享锁,其他事务就不能获取排它锁,也就不能对该资源进行写操作;
  2. 共享锁不能保证数据的一致性,即多个事务同时进行读操作时可能读取到的数据是不一致的。

怎么玩

在select语句末尾加上lock in share mode关键字。

# 对id=1的用户加读锁
select * from user where id=1 lock in share mode;

排它锁/写锁(Exclusive Lock/X锁)

是什么

是用于修改数据时使用的一种锁。当一个事务对一个数据对象加上排它锁时,其他事务既不能对该数据对象加上共享锁,也不能对其加上排它锁。也就是说,其他事物不可远观更不可能亵玩焉

优缺点

  • 优点:
  1. 排它锁可以保证在同一时间只有一个事务可以对资源进行写操作,从而避免了数据的不一致性;
  2. 排它锁在进行写操作时可以保证数据的完整性,从而保证了数据的正确性。
  • 缺点:
  1. 排它锁会阻塞其他事务的读写操作,从而降低了系统的并发性能和吞吐量;
  2. 如果某个事务持有了排它锁并且出现了死锁,其他事务将无法获取该资源的锁,从而无法进行读写操作。

怎么玩

在select语句末尾加上for update关键字。

# 对id=1的用户加写锁
select * from user where id=1 for update;

小扩展(意向锁)

InnoDB所用的表级锁,其设计目的主要是为了在一个事务中揭示下一步将要被请求的锁的类型。

意向共享锁(IS)

表示事务准备给数据行加入共享锁,也就是说一个数据行加共享锁前必须先取得该表的IS锁

意向排他锁(IX)

类似上面,表示事务准备给数据行加入排他锁,说明事务在一个数据行加排他锁前必须先取得该表的IX锁。

怎么玩

意向锁是InnoDB自动加的,不需要用户干预。

小结

MySQL的锁没有优劣之分,只有是否更适合当前场景的合适度之说。

在实际应用中,需要根据具体的场景选择适当的锁类型,以达到合理的性能和数据一致性。例如,如果需要高并发的读写操作,可以使用行锁来避免资源竞争和冲突;如果需要修改整张表的结构,可以使用表锁来避免并发问题。此外,还需要注意锁的范围和持续时间,尽可能减少锁的持有时间,以提高并发性能。

相关文章:

mysql锁分类大全

前言 为什么会出现锁 MySQL中的锁是为了保证并发操作的正确性和一致性而存在的。 当多个用户同时对同一份数据进行操作时&#xff0c;如果不加控制地进行读写操作&#xff0c;就可能导致数据不一致的问题。例如&#xff0c;当多个用户同时对同一行数据进行写操作时&#xff…...

推荐几款主流好用的远程终端连接管理软件

一、介绍 远程终端连接管理软件是管理服务器、虚拟机等远程计算机系统不可或缺的工具之一&#xff0c;它可以通过网络连接到另一台计算机&#xff0c;以执行命令、编辑文件或进行其他管理任务&#xff0c;下面我将为大家介绍几款主流好用的远程终端连接管理软件&#xff0c;并…...

描述性统计

参考文献 威廉 M 门登霍尔 《统计学》 文章目录定性数据的描述方法条形图饼图帕累托图定量数据点图茎叶图频数分布直方图MINITAB 工具在威廉《统计学》一书将统计学分为描述统计学和推断统计学&#xff0c;他们的定义分别如下&#xff1a;描述统计学&#xff1a;致力于数据集的…...

第十四届蓝桥杯三月真题刷题训练——第 7 天

目录 第 1 题&#xff1a;三角回文数 问题描述 答案提交 运行限制 代码&#xff1a; 第 2 题&#xff1a;数数 问题描述 答案提交 运行限制 代码&#xff1a; 第 3 题&#xff1a;倍数问题_同余定理_分情况讨论 题目描述 输入描述 输出描述 输入输出样例 运行限…...

剑指 Offer 57. 和为s的两个数字

一、题目 输入一个递增排序的数组和一个数字s&#xff0c;在数组中查找两个数&#xff0c;使得它们的和正好是s。如果有多对数字的和等于s&#xff0c;则输出任意一对即可。 示例 1&#xff1a; 输入&#xff1a;nums [2,7,11,15], target 9 输出&#xff1a;[2,7] 或者 [7…...

PDF转word在线转换方法!操作简单又高效

相信很多已经工作的人都知道&#xff0c;PDF文件格式的优点在于兼容性强、安全性高&#xff0c;而且查看和传输给他人都很方便。但是&#xff0c;这种格式的文件也有不太方便的地方&#xff0c;那就是不能对文件内容进行编辑和修改。对于许多人来说&#xff0c;如果想要编辑修改…...

Jquery项目中使用vue.js

大家在工作的情况中&#xff0c;可能会遇到之前的老项目采用jq书写&#xff0c;或者修改或者新增功能在jq中&#xff0c;原始jq的项目,代码可维护性很差,一个页面几千行jq,可维护性很差,工作量巨大&#xff0c;所以这个时候大家可以引入vue.js。 第一步&#xff1a;引入vue.js…...

蓝桥杯 删除字符

题目描述 给定一个单词&#xff0c;请问在单词中删除 t 个字母后&#xff0c;能得到的字典序最小的单词是什么&#xff1f; 输入描述 输入的第一行包含一个单词&#xff0c;由大写英文字母组成。 第二行包含一个正整数 t。 其中&#xff0c;单词长度不超过 100&#xff0c…...

析构函数 对象数组 对象指针

&#x1f436;博主主页&#xff1a;ᰔᩚ. 一怀明月ꦿ ❤️‍&#x1f525;专栏系列&#xff1a;线性代数&#xff0c;C初学者入门训练&#xff0c;题解C&#xff0c;C的使用文章 &#x1f525;座右铭&#xff1a;“不要等到什么都没有了&#xff0c;才下定决心去做” &#x1…...

Vue对Axios网络请求进行封装

一、为什么要对网络请求进行封装&#xff1f; 因为网络请求的使用率实在是太高了&#xff0c;我们有的时候为了程序的一个可维护性&#xff0c;会把同样的东西放在一起&#xff0c;后期找起来会很方便&#xff0c;这就是封装的主要意义。 二、如何进行封装&#xff1f; 1、将…...

Android framework HAL(HIDL)

简述 当你在Android系统中使用不同的硬件设备&#xff08;例如摄像头、传感器、音频设备等&#xff09;时&#xff0c;你需要与硬件抽象层&#xff08;HAL&#xff09;进行通信。 HAL是一个中间层&#xff0c;它充当了硬件和应用程序之间的桥梁。但是&#xff0c;由于硬件设备…...

QML 模型(ListModel)

LIstModel&#xff08;列表模型&#xff09; ListModel 是ListElement定义的简单容器&#xff0c;每个定义都包含数据角色。内容可以在 QML 中动态定义或显式定义。 属性&#xff1a; count模型中数据条目的数量dynamic动态角色&#xff0c;默认情况下&#xff0c;角色的类型…...

你还在调戏AI,有的公司已经用ChatGPT开展业务了

近日&#xff0c;OpenAI 正式宣布开放 ChatGPT 和 Whisper 两个模型的 API&#xff0c;API 版本的ChatGPT 不仅功能更多、性能更强&#xff0c;而且还更便宜一一相当于目前 GPT-3 模型价格打一折!划重点OpenAl正式开放 ChatGPT 和 Whisper 模型的 API&#xff0c;目前 SnapChat…...

DatenLord前沿技术分享 No.20

达坦科技专注于打造新一代开源跨云存储平台DatenLord&#xff0c;致力于解决多云架构、多数据中心场景下异构存储、数据统一管理需求等问题&#xff0c;以满足不同行业客户对海量数据跨云、跨数据中心高性能访问的需求。喷泉码具有极高的纠错能力&#xff0c;且具有低延迟、地复…...

基于vivado(语言Verilog)的FPGA学习(1)——了解viviado面板和编译过程

基于vivado&#xff08;语言Verilog&#xff09;的FPGA学习&#xff08;1&#xff09;——了解程序面板和编译过程 每日废话&#xff1a;最近找实习略微一些焦虑&#xff0c;不想找软件开发&#xff0c;虽然有些C和python基础&#xff08;之前上课学的&#xff09;&#xff0c;…...

PACS(CT、CR、DR、MR、DSA、RF医院影像管理系统源码)

PACS具体功能介绍&#xff1a; 病人、采集、观片、三维、报告、照相、退出、文件、图像采集、观片操作、三维、测量标注、诊断报告、照相打印、统计报表、系统管理、帮助、病人浏览器、选择数据源、打开图像、病人登记、工作列表、采集、打开画廊。 DICOM查询/获取&#xff1a…...

Centos7 安装Mysql8.0

1、到指定目录下下载安装包[rootVM-0-14-centos ~]# cd /usr/local/src2、下载mysql8[rootVM-0-14-centos src]# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz3、解压mysql8, 通过xz命令解压出tar包&#xff0c; 然后通过t…...

2023年全国最新道路运输从业人员精选真题及答案18

百分百题库提供道路运输安全员考试试题、道路运输从业人员考试预测题、道路安全员考试真题、道路运输从业人员证考试题库等&#xff0c;提供在线做题刷题&#xff0c;在线模拟考试&#xff0c;助你考试轻松过关。 181.某客运企业拥有55辆营运客车&#xff0c;下列关于该企业设置…...

web worker的基本使用案例

文件目录如下 代码按照顺序分别如下 webworker.html <!DOCTYPE html> <html lang"en"><head><meta charset"utf-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewpo…...

机器看世界

博主简介 博主是一名大二学生&#xff0c;主攻人工智能研究。感谢让我们在CSDN相遇&#xff0c;博主致力于在这里分享关于人工智能&#xff0c;c&#xff0c;Python&#xff0c;爬虫等方面知识的分享。 如果有需要的小伙伴可以关注博主&#xff0c;博主会继续更新的&#xff0c…...

18、指数移动平均——EMA

简介 在深度学习中&#xff0c;经常会使用EMA&#xff08;指数移动平均&#xff09;这个方法对模型的参数做平均&#xff0c;以求提高测试指标并增加模型鲁棒。 指数移动平均&#xff08;Exponential Moving Average&#xff09;也叫权重移动平均&#xff08;Weighted Moving…...

用Go快速搭建IM即时通讯系统

WebSocket的目标是在一个单独的持久连接上提供全双工、双向通信。在Javascript创建了Web Socket之后&#xff0c;会有一个HTTP请求发送到浏览器以发起连接。在取得服务器响应后&#xff0c;建立的连接会将HTTP升级从HTTP协议交换为WebSocket协议。由于WebSocket使用自定义的协议…...

2023年江苏省职业院校技能大赛中职网络安全赛项试卷-学生组-任务书

2023年江苏省职业院校技能大赛中职网络安全赛项试卷-学生组-任务书 2023年江苏省职业院校技能大赛中职网络安全赛项试卷-学生组-任务书第一阶段 (300分) [手敲的任务书 点个赞吧]任务一:主机发现与信息收集 (50分)任务二: 应急响应 (60分)任务三:数字取证与分析(80分)任务四:…...

如何使用码匠连接 MariaDB

MariaDB 是一个免费的、开源的关系型数据库管理系统&#xff0c;由 MariaDB 的创始人 Michael Widenius 于 2010 年创建。它基于 MariaDB&#xff0c;但在对数据存储的处理中加入了一些自己的特性。MariaDB 相对于 MariaDB 而言&#xff0c;具有更好的性能和更好的兼容性&#…...

JavaEE简单示例——Bean的实例化

简单介绍&#xff1a; 在我们之前使用某个对象&#xff0c;那么就要创建这个类的对象&#xff0c;创建对象的过程就叫做实例化。对于Spring来说&#xff0c;实例化Bean的方式有三种&#xff0c;分别是构造方法实例化&#xff0c;静态方法实例化&#xff0c;实例工厂实例化。我…...

1229. 日期问题

目录 题目链接 一些话 流程 套路 ac代码 题目链接 1229. 日期问题 - AcWing题库 一些话 切入点 // 小明知道这些日期都在1960年1月1日至2059年12月31日。 // 这些日期采用的格式非常不统一&#xff0c;有采用年/月/日的&#xff0c;有采用月/日/年的&#xff0c;还有采用…...

Java 中的浅拷贝和深拷贝

无论是浅拷贝还是深拷贝&#xff0c;都可以通过 Object 类的 clone() 方法来完成&#xff1a; /*** 拷贝** author qiaohaojie* date 2023/3/5 15:58*/ public class CloneTest {public static void main(String[] args) throws Exception {Person person1 new Person(23, &…...

【java】 java开发中 常遇到的各种难点 思路方案

文章目录逻辑删除如何建立唯一索引唯一索引失效问题加密字段模糊查询问题maven依赖冲突问题&#xff08;jar包版本冲突问题&#xff09;sql in条件查询时 将结果按照传入顺序排序作为一个开发人员 总会遇到各种难题 本文列举博主 遇见/想到 的例子 &#xff0c;也希望同学们可以…...

ViewBinding 和 DataBinding的使用

1.ViewBinding:视图绑定 通过视图绑定功能&#xff0c;您可以更轻松地编写可与视图交互的代码。在模块中启用视图绑定之后&#xff0c;系统会为该模块中的每个 XML 布局文件生成一个绑定类。绑定类的实例包含对在相应布局中具有 ID 的所有视图的直接引用。在大多数情况下&…...

HTML+CSS入门

CSS概述 CSS指层叠样式表 (Cascading Style Sheets)&#xff0c;用来定义HTML网页中的内容用什么样式来显示。 HTML: 指定网页显示的内容 CSS: 指定内容显示的样式CSS入门案例 <html><head><meta charset"UTF-8"><title>入门案例</tit…...

做网站最便宜多少钱/google网页版登录入口

近期&#xff0c;一些小伙伴说电脑开机出现错误代码0xc0000001&#xff0c;重新启动好几次还是一样&#xff0c;电脑开机出现错误代码0x0000001&#xff0c;一般是设备出现问题&#xff0c;又或者是一些文件损坏导致。遇此故障问题&#xff0c;大家别着急着重装系统&#xff0c…...

wordpress 短信平台/北京刚刚传来特大消息

小程序空间服务器环境配置 内容精选换一换选择Windows开发环境下&#xff0c;安装Eclipse&#xff0c;安装JDK。请安装JDK1.8及以上版本。Eclipse使用支持JDK1.8及以上的版本&#xff0c;并安装JUnit插件。若使用IBM JDK&#xff0c;请确保Eclipse中的JDK配置为IBM JDK。若使用…...

京东网站建设及特点/引擎优化seo是什么

文章目录1背景介绍2 问题描述3 问题处理1背景介绍 做了个屏幕录制程序&#xff0c;可自选屏幕区域进行录制&#xff0c;保存格式可选为mp4&#xff0c;使用ffmpeg实现生成mp4格式文件&#xff0c;全屏幕录制无任何问题&#xff0c;自选区域录制部分情况下生成mp4文件无数据 2…...

一个完美的网站怎么做/长沙网络营销推广公司

首先是有如下数据&#xff0c;设定左边是右边的儿子&#xff0c;右边是左边的父母 Tom Lucy Tom Jack Jone Lucy Jone Jack Lucy Mary Lucy Ben Jack Alice Jack Jesse Terry Alice Terry Jesse Philip Terry Philip Alma Mark Terry Mark Alma要求输出如下所示的爷孙关系&…...

织梦网站后台密码忘记/最新国际消息

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 安全生产模拟考试一点通&#xff1a;N1叉车司机新版试题考前必练&#xff01;安全生产模拟考试一点通每个月更新N1叉车司机考试试卷题目及答案&#xff01;多做几遍&#xff0c;其实通过N1叉车司机复审模拟考试很简单…...

seo网站营销公司/搜索关键词然后排名怎样提升

1.定位到文件夹 Windows: %APPDATA%\syntevo\SmartGit\OS X: ~/Library/Preferences/SmartGit/Unix/Linux: ~/.smartgit/ 2.删除文件夹下的 settings.xml...