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;

MySQL数据库:drop、truncate、delete的区别相关推荐

  1. Mysql的drop/truncate/delete

    drop > truncate > delete drop删除结构与数据 truncate删除表的所有数据,不可恢复 delete有条件删除数据,可以恢复

  2. mysql truncate drop_详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始 | 很文博客...

    不同点: 1. truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该 ...

  3. 详解MySQL中DROP,TRUNCATE 和DELETE的区别

    注意:这里说的delete是指不带where子句的delete语句 相同点: truncate和不带where子句的delete, 以及drop都会删除表内的数据 不同点: 1. truncate和  ...

  4. Mysql之drop、delete、truncate的区别

    一.不同点 1.truncate table 和 delete只删除记录不删除表的结构,drop语句将删除表的结构依赖的约束(constrain),触发器(trigger),索引(index); 语句 ...

  5. 【数据库数据恢复】华为云mysql数据库数据被delete的数据恢复案例

    数据库数据恢复环境: 华为云ECS,linux操作系统: mysql数据库,实例内数据表默认存储引擎为innodb. 数据库故障: 在执行数据库版本更新测试时,用户误将本应在测试库测试的sql脚本执行 ...

  6. Mysql数据库drop表不用跑路,表空间传输助你恢复数据

    今天给大家介绍一种,在Mysql数据库中,利用InnoDb的表空间传输功能,帮助你恢复drop的业务表. Mysql表空间传输限制 要使用Mysql数据库表空间传输功能,有2个限制 1.Mysql数据 ...

  7. MySQL数据库与数据仓库有什么区别

    之前一直有这样的疑问,既然MySQL也可以做分析为什么还要数据仓(如Hive,Hbase等)?而且数据仓库的搭建如此麻烦,维护也不方便,还不如直接用MySQL. 存在即合理,我带着这些疑惑重新看了一些 ...

  8. drop truncate delete区别

    在实际应用中,三者的区别是明确的. 当你不再需要该表时, 用 drop; 当你仍要保留该表,但要删除所有记录时, 用 truncate; 当你要删除部分记录时(always with a WHERE  ...

  9. mysql 用drop和delete方法删除用户的区别

    在学习drop方法删除用户时,按照书上讲的一直没操作成功,后来到网上查了点其他资料,才弄明白drop的方法,贴出来和大家分享一下. (方法一)drop user 用户名; 语法:drop user 用 ...

  10. (转载)mysql 用drop和delete方法删除用户的区别

    (转载)http://hi.baidu.com/yymagento/item/56c3f6184bce8347e75e06db 在学习drop方法删除用户时,按照书上讲的一直没操作成功,后来到网上查了 ...

最新文章

  1. 【linux草鞋应用编程系列】_4_ 应用程序多线程
  2. inovance变频器说明书参数设置_学会西门子与台达变频器通讯,仅需要这4个步骤,你造嘛...
  3. Android系统截屏的实现(附代码)
  4. 文末送书|增强现实:原理与实践
  5. (转)基于Metronic的Bootstrap开发框架经验总结(3)--下拉列表Select2插件的使用...
  6. window 和 linux 环境下杀死tomcat进程——也可以解决其他端口被占用的问题
  7. 新版本发布潮:Ceylon 1.2、Node.js 5.0和Atom 1.1
  8. pkpm字体库下载_pkpm字体库转到cad
  9. 职场:迈过职业生涯中的5个坎
  10. Adjoin the Networks
  11. 天蝎项目整机柜服务器技术规范v1.01,第九章 天蝎项目整机柜服务器技术规范v1.01.pdf...
  12. 奇幻文学的鼻祖、善与恶的经典战争 《魔戒三部曲》[英]J.R.R.托尔金
  13. K-均值聚类(K-means)
  14. 顶配梧桐树金玉满堂增额终身寿险,对抗“资产荒”的高增长神器
  15. 【技术管理】管理核心五要素 - 学习笔记
  16. UTF-8 带BOM 和 UTF-8无BOM 的区别?
  17. android短信和彩信探秘threads
  18. Java获取文件大小
  19. 蜘蛛大战之 站点LOGO(SEO)
  20. 转置-置换-向量空间R

热门文章

  1. django模版标签和继承
  2. 四十五、Redis数据库学习
  3. php订单系统 帝国cms,帝国CMS商城系统在线支付后,订单邮件提醒
  4. 无关于目标or特定于目标:简单且有效的零样本立场检测对比学习方法
  5. 初始化方法中非方阵的维度平均策略思考
  6. 京东 | AI人才联合培养计划
  7. 提升Transformer效率又有新招?基于矩阵分解的线性化Attention方案
  8. 超细节!从源代码剖析Self-Attention知识点
  9. 蓝桥备赛第四周 同余+并查集
  10. 微信:禁用小程序跳转 App;华为商城上架 PlayStation 5;币安涉及洗钱被美监管调查