MySQL原理分析2

本文深入探讨MySQL的事务特性,包括事务的深入分析、锁机制解析,以及如何处理脏读和幻读问题。通过加行锁的方式,讨论了在无主键索引情况下的锁行为,并解释了左开右闭原则如何防止幻读。同时,文章还触及了死锁现象和MVCC在并发控制中的应用,实现千人千面的读写操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL事务深入分析
MySQL锁机制深入分析
MySQL事务与日志原理

在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述脏读A读取了B没有提交的对age的修改。
在这里插入图片描述一次事务中两次读到数据不同。

在这里插入图片描述B插入数据,A第一次计算1,第二次计算2,造成幻读
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述

加行锁
在这里插入图片描述在这里插入图片描述在这里插入图片描述1,如果没有主键索引和唯一索引,innodb会扫描整张表,并将隐藏的聚集索引都锁住。
2.因为回表,辅助索引是二级索引,比如非聚簇索引中搜索到id=1,然后再去聚簇索引去找对应的数据。所以也会锁住主键索引。
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述左开右闭可以保证查询一定范围内第一次查询和第二次查询范围内数据的数量,左开右闭的话插不进来,解决幻读问题。

在这里插入图片描述锁住资源最长时间
在这里插入图片描述在这里插入图片描述
事务1需要事务2的锁,事务2需要事务1的锁

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述MVCC如何做到千人千面
在这里插入图片描述  在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值