mysql 的锁
一、表级锁:MyISAM引擎,可以理解为锁整张表,可以同时读,不可以同时写。
在锁定期间,其它进程无法对该表进行写操作,如果是写锁,则其它进程则不允许读。
二、行级锁:
InnoDB引擎,单独一行记录加锁,可以同时读,不可同时写。
行级锁开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
三、InnoDB行锁
由于InnoDB预设是Row-Level Lock,所以只有[明确]的指定主键,MySQL才会执行Row lock,否则MySQL将会执行Table Lock
例1:(明确指定主键,并且有此记录,Row Lock)
SELECT * FROM products WHERE>
SELECT * FROM products WHERE> 1
2
例2: (明确指定主键,若查无此记录,无lock)
SELECT * FROM products WHERE> 1
例3: (无主键,table lock)
SELECT * FROM products WHERE name='Mouse' FOR UPDATE;
1
例4: (主键不明确,table lock)
SELECT * FROM products WHERE> 1
例5: (主键不明确,table lock)
SELECT * FROM products WHERE>
页:
[1]