前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL数据库:drop、truncate、delete的区别

MySQL数据库:drop、truncate、delete的区别

作者头像
全栈程序员站长
发布2022-06-29 11:44:20
1.3K0
发布2022-06-29 11:44:20
举报
文章被收录于专栏:全栈程序员必看

1、删除速度:drop>truncate>delete;

2、删除方式:

  • (1)执行delete操作时,每次从表中删除一行,并且同时将该行的的删除操作记录在日志文件中。delete可根据where条件删除表中指定的数据,如果不指定where子句,则跟truncate一样,可以删除表中所有记录。
  • (2)truncate通过释放存储表数据所用的页来删除数据,一次性删除表中所有记录,不会将删除的数据记录在日志文件中,只在日志文件中记录页的释放,使用的系统和事务日志资源少,所以执行速度比delete快。对于外键约束引用的表,不能使用 truncate table,而应使用不带 where 子句的 delete 语句。
  • (3)drop则删除整个表的结构和数据,但是被依赖的约束、触发器、索引、依赖于该表的存储过程、函数将被保留,但其状态会变为invalid

3、删除后,表和索引所占空间:

  • (1)delete操作不会减少表或索引所占用的空间;
  • (2)当表被truncate后,这个表和索引所占用的空间会恢复到初始大小,但表结构及其列、约束、索引的定义等保持不变。
  • (3)drop语句将表所占用的空间全释放掉。

4、提交方式:delete是DML,需要手动提交操作才能生效,可以回滚,可以触发触发器;truncate和drop是DDL,会隐式提交,不能回滚,不会触发触发器。

5、使用场景:

  • (1)如果想删除表,当然用drop;
  • (2)如果想保留表而将所有数据删除,而且和事务无关,用truncate即可;
  • (3)如果和事务有关,或者想触发trigger,还是用delete;

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/100076.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年4月9,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档