mysql 清空表——truncate 与delete的区别

  • 清空表

    1. truncate table [表名];
    2. delete from [表名];
    注:
    1. truncate是整体删除(速度较快), delete是逐条删除(速度较慢)。
    2. truncate不写服务器log,delete写服务器log,也就是truncate效率比delete高的原因。
    3. truncate不激活trigger(触发器),但是会重置Identity(标识列、自增字段),相当于自增列会被置为初始值,又重新从1开始记录,而不是接着原来的ID数。而delete删除以后,Identity依旧是接着被删除的最近的那一条记录ID加1后进行记录。
    4. 如果只需删除表中的部分记录,只能使用DELETE语句配合where条件。 DELETE FROM wp_comments WHERE……
原文地址:https://www.cnblogs.com/Pusteblume/p/10205175.html