8.31笔记(GAP锁模拟:基于索引列的扫描)

GAP锁模拟:基于索引列的扫描。
两个会话,同时开启事务,begin;
1会话update set num(索引列)=10 where num <10;
符合条件的的num全部加锁,间隙间数据也会被加锁
2会话
	insert into 某数据(该数据在num值中间间隙值小于更改的范围的值)出现锁等待。
	更新范围超过25%出现行锁。


死锁产生:死锁mysql能自行解决但是会消耗大量资源,解锁之后会自动回滚
两个事务之间出现交叉争用:
模拟:
1会话开启事务,update某值:update city set name='oldliu' where id=1
update city set name='xxx' where id >5
2会话开启事务,update某值:update city set name='lbb' where id=10
同时,这边也更新 update city  set name='yyy' where id <5;
死锁影响全局。
打开死锁记录
vim /etc/my.cnf 
innodb_print_all_deadlocks=1



查看锁等待情况:select * from sys.innodb_lock_waits\G;

事务的一致性ACID的C特性
A.原子性,undo,redo
D.持久性:commit的数据之后,redo(wal)
I.隔离性:isolation level,lock,mvcc(undo)隔离性
由以上特性保证c的一致性。
C.一致性:保证工作前中后数据状态都是完整的。c的特性由以上特性保证的。
   数据页一致性:double write buffer(磁盘区域)
   防止出现坏页,先写到该区域,等写该区域完则重新写入磁盘。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值