MySQL---数据删除方法delete、truncate、drop的区别
其他
2019-01-11 03:06:47
阅读次数: 0
- 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
- truncate和 delete只删除数据不删除表的结构(定义) ,drop语句将删除表的数据以及结构
- delete是DML语句,操作会被放到 rollback segment中,事务提交后才生效,以便进行进行回滚操作(可恢复)。
truncate、drop是DLL语句,操作立即生效,原数据不放到 rollback segment中,不能回滚(不可恢复)。
- delete操作之后表或索引所占的空间不会减少,truncate操作之后表和索引所占用的空间会恢复到初始大小,drop语句将表所占用的空间全部释放。
- 删除速度: delete < truncate < drop ;
总的来说:
删除表内部分数据用delete,删除表内所有数据并且保留表的结构用truncate,删除表或者库用drop
转载自blog.csdn.net/young_foryou/article/details/86256674