锁
在这里我们主要讨论下行级锁
表级
引擎MyISAM,可以理解为锁整张表,可以同时读,不可以同时写。在锁定期间,其它进程无法对该表进行写操作,如果是写锁,则其它进程则不允许读。
行级
引擎INNODB,单独一行记录加锁,可以同时读,不可同时写。行级锁开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
InnoDB锁行
由于InnoDB预设是Row-Level Lock,所以只有[明确]的指定主键,MySQL才会执行Row lock,否则MySQL将会执行Table Lock
例1:(明确指定主键,并且有此记录,Row Lock)
SELECT * FROM products WHERE id='3' FOR UPDATE;
SELECT * FROM products WHERE id='3' and type=1 FOR UPDATE;
1
2
例2: (明确指定主键,若查无此记录,无lock)
SELECT * FROM products WHERE id='-1' FOR UPDATE;
1
例3: (无主键,table lock)
SELECT * FROM products WHERE name='Mouse' FOR UPDATE;
1
例4: (主键不明确,table lock)
SELECT * FROM products WHERE id<>'3' FOR UPDATE;
1
例5: (主键不明确,table lock)
SELECT * FROM products WHERE id LIKE '3' FOR UPDATE;
本文转自lzf0530377451CTO博客,原文链接: http://blog.51cto.com/8757576/1967584如需转载请自行联系原作者