当使用MySQL MyISAM表并发出ALTER TABLE语句来添加列时,MySQL会创建一个临时表,并在覆盖原始表之前将所有数据复制到新表中.
如果该表包含大量数据,则此过程可能非常慢(尤其是在重建索引时),并且要求您在磁盘上有足够的可用空间来存储表的2个副本.这非常烦人.
添加列时Oracle如何工作?在大桌子上快吗?
我总是对能够在没有大量停机时间的情况下进行模式更改感兴趣.我们总是在我们的软件中添加新功能,这些功能需要在每个版本中更改架构.任何建议表示赞赏......
将没有数据的列添加到Oracle中的大表通常非常快.没有数据的临时副本,也不需要重建索引.当您想要将列添加到大型表并将数据回填到所有现有行的新列时,通常会出现缓慢,因为现在您正在讨论影响大量行的UPDATE语句.
添加列可能会导致行迁移.如果您有一个80%已满4行的块,并且您添加的列将逐渐增加每行30%的大小,您最终将达到Oracle必须将4行中的一行移动到另一行的点块.它通过在旧块中留下指向新块的指针来执行此操作,这会导致对该迁移行的读取需要更多I/O. 消除迁移的行可能有些昂贵,虽然假设您使用企业版通常可以在没有停机的情况下进行,但如果您有一些停机时间通常会更容易.但是,行迁移是您通常只需要担心的问题.如果您知道某些表格将来可能会大幅增加行数,