Mysql Innodb 间隙锁浅析
2016-12-13 19:47
281 查看
间隙锁说明
innodb引擎自动使用间隙锁来避免幻读(原因是因为innodb采用单行锁+间隙锁组合而成的行锁,会锁定一个范围和记录本身的行),参数默认innodb_locaks_unsafe_for_binlog为false时开启,True时禁用。
间隙锁的缺点
当高并发访问时执行delete操作和insert操作时,如
delete from user u where u.id = 2; insert into user u values(2);
delete from user u where u.id = 3; insert into user u values(3);
可能会出现乱序,delete from user u where u.id = 2;delete from user u where u.id = 3;这时当执行最后一条插入语句时就会抛出死锁。
这时数据库会扫描索引,数据库会向左扫描扫到第一个比给定参数小的值, 向右扫描扫描到第一个比给定参数大的值, 然后以此为界,构建一个区间,
最终会锁住整个区间内的数据,这就是间隙锁的死锁,这种情况就得修改代码逻辑, 存在才删除,尽量不去删除不存在的记录。
innodb引擎自动使用间隙锁来避免幻读(原因是因为innodb采用单行锁+间隙锁组合而成的行锁,会锁定一个范围和记录本身的行),参数默认innodb_locaks_unsafe_for_binlog为false时开启,True时禁用。
间隙锁的缺点
当高并发访问时执行delete操作和insert操作时,如
delete from user u where u.id = 2; insert into user u values(2);
delete from user u where u.id = 3; insert into user u values(3);
可能会出现乱序,delete from user u where u.id = 2;delete from user u where u.id = 3;这时当执行最后一条插入语句时就会抛出死锁。
这时数据库会扫描索引,数据库会向左扫描扫到第一个比给定参数小的值, 向右扫描扫描到第一个比给定参数大的值, 然后以此为界,构建一个区间,
最终会锁住整个区间内的数据,这就是间隙锁的死锁,这种情况就得修改代码逻辑, 存在才删除,尽量不去删除不存在的记录。
相关文章推荐
- MySQL 参数浅析之 innodb_file_per_table
- Mysql innodb 间隙锁
- mysql存储引擎及MyISAM与InnoDB浅析
- MySQL中InnoDB的间隙锁问题
- MySQL InnoDB redo Log 浅析
- 浅析MySQL InnoDB数据库引擎
- 推荐:mysql锁 innodb下的记录锁,间隙锁,next-key锁
- Mysql innodb 间隙锁: 记录不存在也会加间隙锁
- MySQL中InnoDB的间隙锁问题
- Mysql innodb 间隙锁
- MySQL的存储引擎InnoDB间隙锁
- Mysql innodb 间隙锁
- Mysql innodb 间隙锁
- MySQL 参数浅析之 innodb_file_per_table
- 【MySQL】sync_binlog innodb_flush_log_at_trx_commit 浅析
- Mysql innodb 间隙锁
- MySQL中InnoDB的间隙锁问题
- 【MySQL】sync_binlog innodb_flush_log_at_trx_commit 浅析
- Mysql加锁过程详解(9)-innodb下的记录锁,间隙锁,next-key锁
- Mysql innodb 间隙锁