我认为您可以尝试使用IGNORE添加唯一索引:
ALTER IGNORE TABLE `table` ADD UNIQUE INDEX `name` (`column`);
Query OK, 4524 rows affected (1.09 sec)
Records: 4524 Duplicates: 9342 Warnings: 0
编辑:
这适用于任意多的列:
ALTER IGNORE TABLE `table` ADD UNIQUE INDEX `name` (`col1`, `col2`, `col3`);
查看有关CREATE INDEX的MysqL文档。一个常见的陷阱(至少我曾经碰到过一次)会忘记那NULL = NULL
不是真的(而是NULL
),因此在两列的UNIQUE索引中允许使用{42,NULL}和{42,NULL}。