先删表后建表
-- 删除表
DROP TABLE table_name;-- 创建表
CREATE TABLE table_name (
...
);
使用DROP TABLE:这种方式删除数据也比较快,直接删除整个表结构和数据。但是,这个操作不能回滚,约束和索引会释放,需要重新创建表结构。
清空表
TRUNCATE TABLE table_name;
使用TRUNCATE TABLE:这是删除数据的最快方法,因为它不扫描表中的数据,而是直接删除表的数据并重新创建表。但是,这个操作不能回滚,并且只适用于没有外键约束的表。
删除全部数据
-- 禁用外键约束
SET FOREIGN_KEY_CHECKS = 0;-- 删除数据
DELETE FROM table_name;-- 恢复外键约束
SET FOREIGN_KEY_CHECKS = 1;
如果表中的数据不需要立即删除,可以考虑先临时移除约束,然后删除数据,最后恢复约束。但是,这个方式很有可能造成死锁。
分批删除数据
WHILE 1 = 1 DODELETE FROM table_name LIMIT 10000;IF ROW_COUNT() = 0 THENLEAVE;END IF;
END WHILE;
使用DELETE与LIMIT:如果你需要保留表结构并且想要删除大量数据,可以使用循环来分批删除。这种方法可以回滚,适用于有外键约束的表。
总结
选择哪种方法取决于具体情况,如表是否有外键约束、是否需要事务回滚等。通常TRUNCATE TABLE是最快的方法,但它不适用于所有情况。如果删除操作需要保留事务的原子性,那么DELETE与LIMIT或者在事务中使用TRUNCATE可能是更好的选择。