MySQL中(delete、truncate、drop) 的区别

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  
 

网络毒刘 CSDN认证博客专家 Python 公众号:刘旺学长 数据分析
因为同样的坑不想踩两次而写博客,
也同样为了社会更好的进步...

其实 Python 已经是一个很老的编程语言了,到现在(2019年) Python 已经高龄 28 岁,比很多程序员的年龄都大。现在之所以这么流行和社区、人工智能AI的日益发展,有很大的关系。

千里之行始于足下,还不开始学习 Python编程吗



个人公众号:刘旺学长
一名热爱分享技术的宝藏博主。
公众号回复1024,有免费教程分享。
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: Age of Ai 设计师:meimeiellie 返回首页