如果任何一个长时间不关闭的事务将会导致redo log膨胀,那么有没有更高效的方式来实现MVCC ?...

1. 在MVCC里面,update操作会把原来的行复制一份,并把当前事务号作为改行的修改版本。

相当于每个update操作会多占一行空间,那么这些空间什么时候会被释放呢?

是copy到redo log,默认情况下,redo log在共享表空间

没有引用的情况下,就相当于垃圾数据,等着被清掉 

2. 考虑一个场景

有一个开启的很早很早的事务,但是一直没提交

这时候,这个事务(默认RR)可以查询到之前update完成,之后delete完成的数据

是不是就意味着,该事务开启之后对应table的redo log,都不会被删除?

没有其他高效的方式了吗?

如果任何一个长时间不关闭的事务将会导致redo log膨胀,那么有没有更高效的方式来实现MVCC?

转载于:https://my.oschina.net/yangshj/blog/734459

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值