mysql中删除表记录delete from和truncate table的用法区别:
MySQL中有两种删除表中记录的方法:
(1)delete from语句,
(2)truncate table语句。mysql
delete from语句可使用where对要删除的记录进行选择。delete语句更灵活。
truncate table将删除表中的全部记录。sql
状况一:清空表中的全部记录,可使用下面的两种方法:
delete from tablename
truncate table tablename
其中第二条记录中的table是可选的。post
状况二:删除表中的部分记录,只能使用delete语句。
delete FROM table1 WHERE ;table
区别:
(1)若是delete不加WHERE子句,那么它和truncate table是同样的,但它们有一点不一样,那就是delete能够返回被删除的记录数,而truncate table返回的是0。class
(2)若是一个表中有自增字段,使用truncate table和没有WHERE子句的delete删除全部记录后,这个自增字段将起始值恢复成1.若是你不想这样作的话,能够在delete语句中加上永真的WHERE,如WHERE 1或WHERE true。
delete FROM table1 WHERE 1;方法
上面的语句在执行时将扫描每一条记录。但它并不比较,由于这个WHERE条件永远为true。这样作虽然能够保持自增的最大值,但因为它是扫描了全部的记录,所以,它的执行成本要比没有WHERE子句的delete大得多。总结
(3)还有一点就是,若是要删除表中的全部数据,建议使用truncate table, 尤为是表中有大量的数据, 使用truncate table是将表结构从新建一次速度要比使用delete from快不少,而delete from是一行一行的删除,速度很慢.数据
总结:
delete和truncate table的最大区别是delete能够经过WHERE语句选择要删除的记录。但执行得速度不快。并且还能够返回被删除的记录数。而truncate table没法删除指定的记录,并且不能返回被删除的记录。但它执行得很是快。tab
delete :
与标准的SQL语句不一样,delete支持ORDER BY和LIMIT子句。
delete FROM users WHERE name = 'nike' ORDER BY id DESC LIMIT 6;di