MySQL 8.3 Release Notes
如果您在使用 ALTER TABLE 更改字符列的字符集或排序规则时遇到重复键错误,则原因是新的列排序规则将两个键映射到相同的值,或者表已损坏。在后一种情况下,您应该对表运行 REPAIR TABLE。 REPAIR TABLE 适用于 MyISAM、ARCHIVE 和 CSV 表。
如果您在事务表上使用 ALTER TABLE,或者您使用的是 Windows,则如果您对表执行了 LOCK TABLE,ALTER TABLE 将解锁该表。这样做是因为 InnoDB 和这些操作系统无法删除正在使用的表。