Mysql的锁(S锁和X锁的区别)
admin
2023-04-20 17:43:45
0

共享锁和排它锁

Mysql的锁系统:shared lock 和 exclusive lock (共享锁和排它锁,也叫读锁和写锁,即read lock和write lock)

读锁是共享的,或者说是相互不阻塞的
写锁是排他的,一个写锁会阻塞其他的写锁和读锁
在实际的数据库系统中,每时每刻都发生锁定,当某个用户在修改某部分数据1时,mysql会通过1锁定阻止其他用户对统一数据的读取。

共享锁【S锁】

又称读锁,若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其他事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。

这保证了其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改。

排他锁【X锁】

又称写锁。若事务T对数据对象A加上X锁,事务T可以读A也可以修改A,其他事务不能再对A加任何锁,直到T释放A上的锁。

这保证了其他事务在T释放A上的锁之前不能再读取和修改A。

排他锁用法:for update,比如,select name from table where id=1 for update;

锁的粒度和锁的策略

MySQL有三种锁的级别:页级、表级、行级。

MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。

MySQL这3种锁的特性可大致归纳如下:


  • 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。

  • 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。

  • 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

相关内容

热门资讯

我来教教您“讯奇麻将有挂吗?”... 我来教教您“讯奇麻将有挂吗?”(必胜开挂神器)您好,讯奇麻将这个游戏其实有挂的,确实是有挂的,需要了...
【第一资讯】“新卡农炸/金/花... 您好:新卡农炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在...
终于了解“掌酷天天开心可以开挂... 您好:掌酷天天开心这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款...
最新引进“九九山城麻将辅助器?... 您好:九九山城麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
终于明白“新超凡牛牛可以开挂吗... 终于明白“新超凡牛牛可以开挂吗?”(太坑了原来有挂)您好,新超凡牛牛这个游戏其实有挂的,确实是有挂的...
今日重大通报“衡阳丫丫竞技开挂... 您好:衡阳丫丫竞技这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款...
今日重大通报“新全游是不是有挂... 网上科普关于“新全游有没有挂”话题很是火热,小编也是针对新全游作*弊开挂的方法以及开挂对应的知识点,...
今日重磅消息“达人十三水可以开... 网上科普关于“达人十三水有没有挂”话题很是火热,小编也是针对达人十三水作*弊开挂的方法以及开挂对应的...
玩家最新攻略“玄龙炸/金/花究... 家人们!今天小编来为大家解答玄龙炸/金/花透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...
【第一消息】“新九天牛牛开挂器... 【第一消息】“新九天牛牛开挂器?”(太坑了果然有挂)您好,新九天牛牛这个游戏其实有挂的,确实是有挂的...