- 概述
Mysql常用引擎有MYISAM和InnoDB,而InnoDB是mysql默认的引擎。MYISAM不支持行锁,而InnoDB支持行锁和表锁。
- 行锁:
- 共享锁(S):允许一个事务去读一行,阻止其他事务获得相同的数据集的排他锁(读的时候,其他可以读,但是不能写)。
- 排他锁(X):允许获得排他锁的事务更新数据,但是阻止其他事务获得相同数据集的共享锁和排他锁(写的时候,其他事物不能读和写)。
- sql语句中锁使用
对于UPDATE、DELETE和INSERT语句,InnoDB会自动给涉及数据集加排他锁;
对于普通SELECT语句,InnoDB不会加任意锁,当前读(特殊的读操作,需手动加上共享锁)。
- SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE; #共享锁
- SELECT * FROM table_name WHERE ... FOR UPDATE; #排他锁
- insert into table values (…); #排他锁
- update table set ? where ?; #排他锁
- delete from table where ?; #排他锁
- 表级锁相关
- 为了允许行锁和表锁共存,实现多粒度锁机制,InnoDB还有两种内部使用的意向锁(意向共享锁(IS)和意向排他锁(IX))。这两种意向锁都是表锁。意向锁是InnoDB自动加的,不需要用户干预。
- mysql的行锁是通过索引加载的,即行锁是加在索引响应的行上的,要是对应的SQL语句没有走索引,则会全表扫描,行锁则无法实现,取而代之的是表锁。