mysql锁

一、mysql锁类型
行锁、表锁、共享锁、排他(独享)锁
表锁:对整张表进行加锁,当表被加锁时,整张表不可被修改;
1、由于是整张表加锁,所以该锁颗粒较大更容易产生加锁冲突;
2、因为不需要通过索引定位到对应的数据,所以加锁的速度更快;
3、因为表锁一次性锁住了整张表,所以相对来说并发更低

备注:当手动锁定整张表时,需要同时锁定表的所有别名,否则会报错

查看表锁的使用情况:show status like ‘table%’;
行锁:对表中的行数据进行加锁,当行数据被加锁时,同样不可被修改;
1、因为是行级加锁,所以该锁颗粒更小,获取数据加锁的冲突也更小;
2、由于需要通过索引定位到行数据,所以加锁的速度相对更慢;
3、因为是行数据进行加锁,所以有可能会有大量的行数据被逐步加锁,并发更高
两阶段锁协议:当事务开始时,需要使用到锁时才会对数据进行加锁,但是当不需要锁时,该事务不会立刻释放锁,而是等待事务结束之后才释放。这样可以确保两个事务不会发生修改冲突
例:A事务修改了id为1的数据,B事务也对id为1的数据进行了修改。
但此时A尚未提交,根据两阶段锁协议,不会释放锁,所以B事务会进行阻塞,等待A事务提交后,B事务才会进行commit提交
死锁的产生:是因为A事务对B事务修改的行数据加锁了->但B事务也对A事务修改的数据进行加锁,这样就会导致两个事务互相等待对方的数据进行锁释放,即产生了死锁
死锁处理策略:
等待超时->innodb_lock_wait_timeout
手动发起死锁检测,主动回滚其中一个事务,让另一个事务继续执行->innodb_deadlock_detect

共享锁:多事务可读不可写
排他锁:单事务访问,其他事务不可读不可写

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值