在出现问题时,事务可以通过预写日志恢复一致性。也就是说,预写日志包含用于修复已变异行的条目的信息。但是B+树索引呢?当然,SQL事务需要输入预写日志。但是当插入发生在B+树上时,会改变B+树的状态。事务如何恢复B+树的状态。如何在事务上下文中实现B+树以保持一致性?
发布于 2013-11-26 02:11:38
这将由不同的RDBMS以不同的方式处理。在oracle的情况下,对索引的更改分为两个操作:所谓的索引拆分和索引插入。只有当索引块中没有足够的空间时,索引拆分才是必要的。索引拆分的操作作为所谓的递归事务执行。索引拆分不会回滚,但是插入索引是。
https://stackoverflow.com/questions/20206496
复制相似问题