表锁 -意向共享锁和意向排他锁

意向锁是由数据引擎自己维护的,用户无法手动操作意向锁。

意向共享锁:IS锁,表示事务准备给数据行加入共享锁,也就是说一个数据行加共享锁前必须先取得该表的IS锁。

意向排他锁:IX锁,表示事务准备给数据行加入排他锁,说明事务在一个数据行加排他锁前必须先取得该表的IX锁。

为什么需要意向锁呢?
有这么一个场景,当一个事务想要给一张表加上表锁,其前提是没有其他任何事务已经锁定了这张表的任意一行数据。
也就是说,需要去全表扫描,看是否有哪一行数据被其他事务锁定了,但是这非常低效。
因此引入了意向锁,意向锁相当于一个标识,表示是否有其他事务锁定该表的其他行数据。

给全表上锁:lock tables 表名 write/read;
解锁:unlock tables;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值