带你了解MySQL数据库中的全局锁、表级锁、行级锁
在 MySQL 数据库中,数锁表锁有很多各种各样的据库级锁锁,这些锁大致可以分为三类:全局锁、全局表级锁、行级行级锁。数锁表锁这篇文章小编就带你简单了解一下这三种锁。据库级锁

1. 全局锁
全局锁是全局粒度比较大的锁,基本上也使用不上,行级就像我们家的数锁表锁大门一样,控制着整个数据库实例。据库级锁全局锁就是全局对整个数据库实例加锁,让整个数据库处于只读状态。行级
MySQL 提供了一个加全局读锁的数锁表锁方法,命令是据库级锁 Flush tables with read lock (FTWRL),加锁之后整个数据库实例处于只读状态,全局有关数据操作的命令都会被挂起阻塞,例如数据更新语句、数据定义语句、更新类事务语句等等。
所以全局锁一般只用于全库备份的时候,一般只用在不支持一致性读的存储引擎做全库备份时,比如 MyISAM 这种不支持一致性读的存储引擎做全库备份时需要使用全局锁,像 InnoDB 引擎做全库备份时不需要使用全局锁。IT技术网
2. 表级锁
表级锁是 MySQL 很基本的锁策略,并且是开销最小的策略,它锁住的不是整个数据库实例,而是一张表。
表级锁跟全局锁一样,MySQL 数据库提供了加锁的命令:lock tables … read/write。例如 lock tables t1 read, t2 write; 命令,则其他线程写 t1、读写 t2 的语句都会被阻塞。同时,线程 A 在执行 unlock tables 之前,也只能执行读 t1、读写 t2 的操作。连写 t1 都不允许,自然也不能访问其他表。
我们可以使用 unlock tables 主动释放锁,如果没有使用的话,在客户端断开的时候自动释放。
表级锁存在一个问题,如果一个查询正在遍历一个表中的数据,免费源码下载而执行期间另一个线程对这个表结构做变更,删了一列,那么查询线程拿到的结果跟表结构对不上。为解决这个问题,MySQL 5.5版本之后引入了元数据锁(meta data lock,MDL),MDL 是数据库自动加锁,有以下两个特点:
读锁之间不互斥,因此你可以有多个线程同时对一张表增删改查。
读写锁之间、写锁之间是互斥的,用来保证变更表结构操作的安全性。因此,如果有两个线程要同时给一个表加字段,其中一个要等另一个执行完才能开始执行。
3. 行级锁
行级锁顾名思义就是针对数据库表中的行记录加锁,行级锁可以很大程度的支持并发处理,但是同时也带来了很大的锁开销。
行级锁比较容易理解,比如事务 A 更新了一行,而这时候事务 B 也要更新同一行,则必须等事务 A 的操作完成后才能进行更新。站群服务器
并不是所有的存储引擎都支持行级锁,比如MyISAM 引擎就不支持行级锁,这意味着 MyISAM 存储引擎要控制并发只能使用表级锁。
InnoDB 引擎实现了行级锁,InnoDB 存储引擎中实现了两种标准的行级锁:
共享锁(S Lock):允许事务读一行 排它锁(X Lock):允许事务删除和更新一行共享锁是兼容锁,就是当一个事务已经获得了行 r 的共享锁,其他事务可以立即获得行 r 的共享锁,因为读并未改变行 r 的数据。
排他锁是非兼容锁,如果有事务想获取行 r 的排他锁,若行 r 上有共享锁或者排它锁,则它必须等其他事务释放行 r 的锁。
在 InnoDB 存储引擎中,默认情况下使用的是一致性的非锁定行读,也就是通过行多版本控制器来读取行数据,我们可以显示的为行加上共享锁和排它锁,语句如下:
SELECT ..... FOR UPDATE:对读取的行记录加一个排它锁,其他事务想要在这些行上加任何锁都会被阻塞 SELECT ....... LOCK IN SHARE MODE:对读取的行记录加一个共享锁,其他事务可以向被锁定的记录加共享锁,但是想要加排它锁。则会被阻塞。相关文章
电脑C盘满了怎么删除没用的东西?(解决电脑C盘存储问题的实用方法)
摘要:随着时间的推移,电脑的C盘存储空间逐渐变得紧张。当C盘满了之后,电脑的性能和速度都会受到影响。了解如何删除没用的东西以释放C盘空间是非常重要的。本文将为您介绍一些实用的方法来解决这...2025-11-04
安全风险和数据保护漏洞不仅仅是拥有正确的防御技术的问题。除了自己处理在线服务外,联网设备也扮演着越来越重要的角色:智能电表、智能电视、前门的智能锁或育儿过程中的婴儿摄像头等服务并存储非常私密的数据——2025-11-04
ElasticSearch服务器配置错误,暴露579GB用户网站记录
hackread 资讯网站消息,两台配置错误的 ElasticSearch 服务器共暴露了约 3.59(35 9019902)亿条记录,这些记录在 SnowPlow Analyt2025-11-04- 复制1: updatet_test1setlio=0whereobject_idin(101,102); 2: updatet_2025-11-04
三星Note3和iPhone5s拍照对比(以画质、色彩还原和功能性为考量,哪款手机更适合你?)
摘要:在如今的智能手机市场上,拍照已经成为人们购买手机的重要考量之一。三星Note3和iPhone5s作为当时两大热门机型,在拍照方面都有着不俗的表现。本文将就画质、色彩还原和功能性三个...2025-11-04
2016年,图灵奖得主Yann LeCun 表示,机器学习技术在未来的核心挑战就是要实现从没有标签、未经人工处理的原始数据中学习知识,即无监督学习(unsupervised2025-11-04

最新评论