意向锁是由数据引擎自己维护的,用户无法手动操作意向锁。
意向共享锁:IS锁,表示事务准备给数据行加入共享锁,也就是说一个数据行加共享锁前必须先取得该表的IS锁。
意向排他锁:IX锁,表示事务准备给数据行加入排他锁,说明事务在一个数据行加排他锁前必须先取得该表的IX锁。
为什么需要意向锁呢?
有这么一个场景,当一个事务想要给一张表加上表锁,其前提是没有其他任何事务已经锁定了这张表的任意一行数据。
也就是说,需要去全表扫描,看是否有哪一行数据被其他事务锁定了,但是这非常低效。
因此引入了意向锁,意向锁相当于一个标识,表示是否有其他事务锁定该表的其他行数据。
给全表上锁:lock tables 表名 write/read;
解锁:unlock tables;