求助,我不确定自己是否正确理解了数据库的锁机制?-灵析社区

莫克先森

求后端前辈帮忙看一下我绘制的时序图中,我对数据库锁的理解是否正确??? 今天看见一篇讲解 “先删除缓存还是先更新数据库” 的文章看不懂, 我主要是没搞懂“数据库的‘锁’机制”在“并发删除缓存+更新数据库”这个问题中,究竟是怎么运作的?? 因为我在学习mysql时,了解到进行更新操作时,会加上互斥锁,所以理论上更新和查询操作必定是串行的,但按照这篇文章的描述,似乎出现了“数据库更新操作”与“数据库查询操作”同时发生的情况???? 我绘制了如下的并发时序图,希望大家判断一下我对于数据库锁的的理解是否正确???? ![image.png](https://wmprod.oss-cn-shanghai.aliyuncs.com/c/user/20241008/a2cc0f5eac37af5408e99cf49c1c65ae.png) ![image.png](https://wmprod.oss-cn-shanghai.aliyuncs.com/c/user/20241008/552718865c4675f385027db69ebe1cd0.png) ![image.png](https://wmprod.oss-cn-shanghai.aliyuncs.com/c/user/20241008/995b5ce1ec3eacf42fc29b668fa439af.png) 以下是原文链接,请各位大佬直接跳去阅读“「先删缓存,再更新数据库」”这段描述: [https://mp.weixin.qq.com/s?__biz=MzU1NTA0NTEwMg==&mid=2247484...](https://link.segmentfault.com/?enc=P3x%2FdSJRAkIh%2B1QUQAuWXQ%3D%3D.0AKl4GmDq%2FSU%2BKK%2Be2tqcCRNYc2b9uw8eGbaDWCe%2BOhf%2BsSntBsszQTFw8iZYSkwh%2BJ5xyV%2F%2FdPcEeoMeFhZO6cZdb67YadOBqcymewYDvvThjVWwG5E%2F2RkDqcUw%2BXR%2Fr%2FblUY0atmg4OZaJCo%2BLratfRGXWJdp9%2FdzTOmlI0%2F5s2Ww9%2FE3IDv0LHsQyjqsaaB0sFDo7BFI0ff8UMn2mVl61ZCQ0V1NEM6RhYYv7RqeFBrjAVhLliqvjAqNNTVUSMuSwzTk%2FQc7orrOxwSkulWN9MDTqAfj7SZj2BxVHBykTaHnENIFUJsLy31RP%2F7z4Zd33QB9x4C1IyV20gavzg%3D%3D) 我比较希望知道我绘制的详细版时序图是不是正确理解了数据库中的 “锁” 对于 “先删除缓存还是先更新数据库” 这个问题产生的影响。

阅读量:207

点赞量:0

问AI
«似乎出现了“数据库更新操作”与“数据库查询操作”同时发生的情况» mysql的读默认是非锁定读,也叫快照读,就是不加锁的,所以尽管当一条数据在更新的时候加了排他锁,但是读操作是不需要加锁的,所以读操作和更新操作可以同时进行,了解下mysql的"MVCC机制"。而当你使用select ... for update进行查询时,这时候就会加上排他锁,其他线程需要等待锁释放才能更新该数据