1. 在MVCC里面,update操作会把原来的行复制一份,并把当前事务号作为改行的修改版本。
相当于每个update操作会多占一行空间,那么这些空间什么时候会被释放呢?
是copy到redo log,默认情况下,redo log在共享表空间
没有引用的情况下,就相当于垃圾数据,等着被清掉
2. 考虑一个场景
有一个开启的很早很早的事务,但是一直没提交
这时候,这个事务(默认RR)可以查询到之前update完成,之后delete完成的数据
是不是就意味着,该事务开启之后对应table的redo log,都不会被删除?
没有其他高效的方式了吗?
如果任何一个长时间不关闭的事务将会导致redo log膨胀,那么有没有更高效的方式来实现MVCC?