在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

MySQL数据库中怎么实现全局锁和表级锁

136次阅读
没有评论

共计 1524 个字符,预计需要花费 4 分钟才能阅读完成。

这篇文章给大家介绍 MySQL 数据库中怎么实现全局锁和表级锁,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1. 全局锁

全局锁是粒度比较大的锁,基本上也使用不上,就像我们家的大门一样,控制着整个数据库实例。全局锁就是对整个数据库实例加锁,让整个数据库处于只读状态。

MySQL 提供了一个加全局读锁的方法,命令是 Flush tables with read lock  (FTWRL),加锁之后整个数据库实例处于只读状态,有关数据操作的命令都会被挂起阻塞,例如数据更新语句、数据定义语句、更新类事务语句等等。

所以全局锁一般只用于全库备份的时候,一般只用在不支持一致性读的存储引擎做全库备份时,比如 MyISAM   这种不支持一致性读的存储引擎做全库备份时需要使用全局锁,像 InnoDB 引擎做全库备份时不需要使用全局锁。

2. 表级锁

表级锁是 MySQL 很基本的锁策略,并且是开销最小的策略,它锁住的不是整个数据库实例,而是一张表。

表级锁跟全局锁一样,MySQL 数据库提供了加锁的命令:lock tables hellip; 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:对读取的行记录加一个共享锁,其他事务可以向被锁定的记录加共享锁,但是想要加排它锁。则会被阻塞。

关于 MySQL 数据库中怎么实现全局锁和表级锁就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-01发表,共计1524字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 欧美综合图区亚洲综合图区 | 国产精品人人做人人爽 | 在线观看中文字幕一区 | 欧美大屁股精品毛片视频 | 精品欧美一区二区三区免费观看 | 一级视频在线观看 | 免费人妻精品一区二区三区 | 俺来也俺去啦久久综合网 | 国产dvd毛片在线视频 | 日韩中文字幕精品视频在线 | 色香欲综合成人免费视频 | 超碰97久久国产精品牛牛 | 91色综合久久 | 一级成人a毛片免费播放 | 中文字幕久久亚洲一区 | 久久一级视频 | 国产欧美日韩在线播放 | 无码少妇一区二区 | 中文字幕在线视频不卡 | www.男人的天堂.com | 日韩欧美在线不卡 | 色爱区区域综合网 | 日本少妇人妻xxxxx18免费 | 无码av中文一区二区三区桃花岛 | 亚洲黄色性视频 | 天堂国产一区二区三区四区不卡 | 884hutv四虎永久黄网 | 国产无遮挡裸体免费视频在线观看 | 免费精品国产人妻国语 | 麻豆久久精品免费看国产 | 久久精品国产亚洲沈樵 | 亚洲香蕉视频综合在线 | 九九九久久久 | 高清不卡毛片免费观看 | 欧美成人免费观看 | 人妻少妇无码精品视频区 | 国产成人精品免费视频 | 久久99精品国产99久久6尤物 | 国产精品高清视亚洲精品 | 做a小视频| 国内精品久久久久久影院老狼 |