-
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 ;