mysql是表级锁还是行级锁_-mysql-锁机制分为表级锁和行级锁

原标题:-mysql-锁机制分为表级锁和行级锁

声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。

mysql锁机制分为表级锁和行级锁 myISAM 引擎不支持事物! 排他锁:

Set Autocommit=0; // 把事物设置成手动事物!

排他锁又称为写锁,简称X锁 排他锁就是不能与其他锁并存,如A事务获取了一行数据的排他锁,事务就不能再获取该行的其他锁 必须等A事物的排他锁结束才能对一行数据进行增删改! mysql InnoDB引擎默认的修改数据语句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类型,如果加排他锁可以使用select ...for update语句 实验1:

下图两个用户都设置了手动事物 实验证明 A 把数据删了 B还能查到 B也要进行commit 提交或者roll回滚才能看到修改后的数据!

a27ba9202e1ded93f688524e41f9ccf0.png 实验2:

A事物还在执行 B事就对这行数据进行操作 B事物卡住在这里!

2bfe9d987ec572619382c590b2cc2e7a.png 实验3:

A把sid=1的数据改成了2然后b要把sid的数据改成5 结果失败了 原因是已经没有sid=1 这条数据了早就被A修改成2了如果B的条件是 把sid=2的数据修改成5 那就能操作成功了!

9a2bd3ccae5f9724740e0cf7bd3f99dd.png 实验4:

A把查询出来的数据加上排他锁B也对这条数据去加排他锁然后卡住了要等A执行commit提交 A的排他锁才能结束!

8e5b5b939b27e459e46d37abb77eb03f.png 下图用工具测试:

排他锁 A用户已经把这个表用排他锁锁住了B用户去修改数据 然后卡在这里要等A用户执行Commit 提交 B用户才能执行

e65fd941a5365c61c2a3f2364eb5e2a4.png

再看看下图 结果是10因为A用户把sid改成10B用户的条件是sid=1没有此条数据 所以修改不上!

d6c9c9f9e780a71ce6f3097ed2e14013.png 共享锁:

Lock in share mode

第一 共享锁不能与排他锁共存在!

第二 共享锁在自动事物的情况下不会发生冲突

第三 共享锁在手动事物的情况下会出现一系列问题!

第四 共享锁可以多个用户对同一条记录锁定! 实验1:

在手动事物的情况下 A先对这一行数据进行了排他锁 然后B用户又去对这行数据进行共享锁 死活不给B用户操作 要等A用户把这个事物处理完才能给B用户进行排他锁! 反之结果还是一样 排他锁和共享锁不能共存!

a5860fc4eead6914050151755991dc17.png

7977f99bc890362115fa976b9fc9d5f7.png 实验2:

在手动事物下 A和B 都对这一条数据加上共享锁了 然后A事务要修改 会处于等待状态 他在等B用户来操作 只要B一来操作 系统就会把B用户掐死掉 先来的成功执行 后来的直接被干掉

cc3ce7d9d45783b65787a736e67ca9e9.png 实验3:

A用户对sid=1记录共享锁锁定B用户对Sid=2记录共享锁锁定然后A用户去修改sid=2的记录 卡住在那里等B来操作 B一来操作 B就完蛋了!这个故事告诉我们 被干掉总是B用户!

ea156ac2201a89388ec36b0d47e43680.png Sqlyog实验

双方各锁了一条数据

0597f9eb75c92117a2718680e05bba29.png

A对B锁定的数据进行更改A处于等待B对A的数据进行改变B用户的锁干掉了

1b33d2383c335d3b821881ef6fbdbe6c.png

最后两个人都把事物提交或者回滚就能查询出真实数据了!

f1e094cdec064ab6ff3b90be4629c2ae.png

后执行的遭殃 直接被干掉了!

责任编辑:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值