什么是MVCC?

MVCC是一种数据库的并发控制策略,就是为了解决多个用户同时访问数据库修改同一数据所造成的问题,如何解决这个问题了?
就是通过创建同一个数据的不同的版本,通过创建时间的不同,最后进行数据合并,其就不用给数据库上锁了,其实数据库的锁,虽然说InnoDB已经非常牛逼了,可以使用行级锁,但是如果遇到多个用户访问同一个数据,那么行级锁也没办法,何况这样上锁也是非常消耗性能,还会影响客户体验,查询要等好长时间,所以了就用MVCC,多版本并发控制
举个例子吧
比如你正在查看手机银行卡里面的金额,但是这个时候张三正在给你转账,意味着你银行金额的信息正在被俩个人读取,如果还有人看你银行卡金额,那么就是多个人在同时读取你的数据,那么如果用锁的话,那么只能一个人访问,而且问题是那个人访问,这个也是个大问题,别的人只能一直处于查询界面,这样都觉得太卡了,太影响体验了,那么就每个人操作就给整一个版本的数据,不过得有创建时间,这个时间必须十分精准,后面好进行数据进行一致,后面张三转账结束,你又看了一下银行卡金额,那么就是最新的数据了,这就是MVCC,多版本并发控制

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值