mvcc是怎么实现无锁的,网上全都是说读视图,但是就算有读视图,也要先去读取数据行的事务ID,如果这个事务ID可见,那么这个数据行可见,但是其他并发写可能会改变这个数据行啊,读操作还是可能读到一个中间结果,这怎么解决,求佬解惑
全部评论
mvcc解决的是快照读。利用多版本控制执行的。也就是说修改操作并不是直接在原来上面修改。因为要保持老版本。利用undo log日志。
1
送花
回复 分享
发布于 06-10 10:45 广东
可以理解简单,一个修改操作提交会放入到链头,而且在他之前的快照读事务,读取到的链中的数据。
点赞
送花
回复 分享
发布于 06-10 10:48 广东
现代汽车中国前瞻数字研发中心
校招火热招聘中
官网直投
我怎么感觉没懂通你这个描述呢
点赞
1
回复 分享
发布于 06-10 10:51 山东
只要保证rollptr和tra index原子修改即可 正在修改的数据当前读是看不到的
点赞
送花
回复 分享
发布于 06-13 12:08 广东

相关推荐

点赞 13 评论
分享
牛客网
牛客企业服务