当我杀死一个仍在处理的alter table线程时会发生什么?

如果你改变了一个表来添加一个索引,如果这个线程在处理过程中被终止了,会发生什么?

包含MySQL:

在ALTER TABLE期间,在从原始表中读取每一行的行之前检查kill标志。 如果kill标志被设置,则语句被中止,临时表被删除。

编辑:只要确保它不会导致任何其他问题。

有什么不清楚的呢?

MySQL使用新的数据结构创build一个临时表,从原始表复制数据,当所有事情完成时,使用临时表作为主表。

如果这在任何步骤都失败(可能是由于ALTER TABLE语句的中止),临时表将被删除而不会发生任何事情。