delete、truncate、drop的用法 MySQL 数据表中delete删除数据的通用语法:

###删除 students_tbl 表中 student_id 为3 的记录:
delete from students_tbl where student_id=3;

 MySQL 数据表中truncate删除数据的通用语法:

###删除 students_tbl 表中的所有记录:
truncate table students_tbl
MySQL 数据表中drop删除数据的通用语法:

###删除名为 students 的数据库:
drop database students

 delete、truncate、drop的区别
 

 truncate和 delete只删除数据不删除表的结构(定义) ,drop语句将删除表的数据以及结构
 
delete是DML语句,操作会被放到 rollback segment中,事务提交后才生效,以便进行进行回滚操作(可恢复)。
truncate、drop是DLL语句,操作立即生效,原数据不放到 rollback segment中,不能回滚(不可恢复)。
 
delete操作之后表或索引所占的空间不会减少,truncate操作之后表和索引所占用的空间会恢复到初始大小,drop语句将表所占用的空间全部释放。
 

删除速度: delete  < truncate < drop ;

总结:

1、delete 语句可以使用where子句实现部分删除,而truncate不可以,会将表中的整个数据全部删除,使用时,可以按需求选择; 
2、如果想从表中删除所有的数据,不要使用delete,可以使用truncate语句,因为这样执行速度更快。truncate语句实际是删除原来的表然后重新建立一个新表; 
3、在没有备份情况下,谨慎使用 drop 与 truncate。要删除表结构使用drop; 
4、对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
 

 删除表内部分数据用delete,删除表内所有数据并且保留表的结构用truncate,删除表或者库用drop