mysql 行级锁


在这里我们主要讨论下行级锁


表级 

引擎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如需转载请自行联系原作者


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值