首页 > 数据库技术 > 详细

innodb的锁和高并发

时间:2018-04-24 13:18:57      阅读:189      评论:0      收藏:0      [点我收藏+]

1 innodb的锁

1.1 s锁,即读锁,即share锁

1.2 x锁,即写锁,排他锁

1.3 s锁和x锁之间的关系

多个读锁可以共存,但是读锁不可以和写锁共存。写锁和写锁不可以共存。

1.4 间隙锁

就是对一段数据加锁,比如id大于3小于10的行加锁,防止插入id=4的数据。

2 innodb高并发

适合于读多写少的高并发,所以要想获取高并发,就要读写分离。

3 死锁

事务A有了1要2,事务B有了2要1。

4 innodb的三种行锁

第一,record lock

单个行上的锁。

第二,gap lock

间隙上的锁,不包括行本身,解决幻读。

第三,next lock

包括间隙和行本身。

5 锁是附加在sql语句中的,并不需要显示设置

快照读,不需要加锁:

select * from xxx-table where a = 1;

当前读

select * from xxx for update;

insert into xxx-table values(xxx);

这些需要加排他锁。

6 所谓的两阶段锁

就是把锁操作分成加锁阶段和解锁阶段。

 

参考:

http://hedengcheng.com/?p=771

锁是mysql中最难的,加什么锁,跟事务的隔离级别,什么索引等都有关系。

 

innodb的锁和高并发

原文:https://www.cnblogs.com/hustdc/p/8927245.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!