TRUNCATE:用于删除一个表中的所有行,但保留表的结构和定义。可以使用这个命令快速清空一个表,而不必逐行删除每个记录。与DELETE语句相比,TRUNCATE TABLE操作更加高效,因为它不会记录在事务日志中,并且不会逐行删除数据,而是直接删除整个表的数据。 TRUNCATE TABLE语句可以与WHERE子句一起使用,以删除满足特定条件的行。如果不使用WHERE子句,则将删除表中的所有行。
注意,执行此操作将无法撤销。在执行 TRUNCATE 操作之前,建议先备份数据或进行其他必要的预防措施。
TRUNCATE TABLE '表名';
当在MySQL数据库中进行数据删除或更新操作的时候会产生数据碎片。当数据被删除或更新时,MySQL并不会立即回收这些空间,而是将其标记为可重用或保留状态。这就导致了数据库中存在大量的未利用空间,即碎片。数据碎片在物理存储和逻辑存储的位置顺序上不一致,可能会影响数据库性能,包括查询速度下降、磁盘空间浪费等问题。
INSERT INTO SELECT:用于从一个表复制数据到另一个表
INSERT INTO table2 (column1, column2, ..., columnN)
SELECT column1, column2, ..., columnN FROM table1 WHERE condition;
INSERT INTO high_paid_employees (id, name)
SELECT id, name FROM employees WHERE salary > 50000;
UPDATE SELECT:将一个表中的数据更新到另一个表中
UPDATE table2 SET column1 = (SELECT column1 FROM table1 WHERE condition) WHERE condition;