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

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

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.net/100076.html原文链接:https://javaforall.net

(0)
上一篇 2021年4月9日 上午8:00
下一篇 2021年4月9日 上午9:00


相关推荐

  • LoadRunner教程07:回放测试脚本

    LoadRunner教程07:回放测试脚本1、设置runtimesetting,在vuser->runtimeseting下设置,如下图所示:2、实时观察回放的图像,在tools->generaloptions下设置,如下图所示:3、回放脚本,点击上面的运行按钮,可以回放脚本,有静态和动态运行(会标识出当前运行在哪一行代码)两种方式,在view-animatedrun中设置4、查看resu

    2022年5月10日
    40
  • Cursor 安装(一文讲透)

    Cursor 安装(一文讲透)

    2026年3月16日
    2
  • netty源码之ByteBuf详解

    netty源码之ByteBuf详解一 背景简介 ByteBuf 顾名思义 就是字节缓冲区 是 Netty 中非常重要的一个组件 熟悉 jdkNIO 的同学应该知道 ByteBuffer 正是因为 jdk 原生 ByteBuffer 使用比较复杂 某些场景下性能不是太好 netty 开发团队重新设计了 ByteBuf 用以替代原生 ByteBuffer 二 ByteBuf 和 ByteBuffer 对比下面用图示来展示 ByteBuf 和 ByteBuffer 工作原理 ByteBufferBy 依靠 flip 来切换模式 在读模式下

    2026年3月16日
    2
  • VS code安装和使用技巧

    VS code安装和使用技巧VSCode是微软提供的一款轻量级但功能十分强大的编辑器,内置了对JavaScript,TypeScript和Node.js语言的支持,并且为其他语言如C++,C#,Python,PHP等提供了丰富的扩展库和运行时。一:VSCode的安装(去下载),1.1:VSCode的当前版本为1.18,支持Windows,Ubuntu,Mac1.2:安装VS

    2022年5月22日
    93
  • activity生命周期_activity的生命周期有哪些状态

    activity生命周期_activity的生命周期有哪些状态一、概述方法简述onCreate()//在系统首次创建Activity时触发在onCreate()方法中,您需执行基本应用启动逻辑,该逻辑在Activity的整个生命周期中只应发生一次。例如,onCreate()的实现可能会将数据绑定到列表,将Activity与ViewModel相关联,并实例化某些类范围变量。此方法接收savedInstanceSta…

    2022年8月16日
    9
  • 一篇文章,Vue快速入门!!!

    一篇文章,Vue快速入门!!!①Vue概述及第一个Vue程序(HelloWorld)1.1什么是MVVMMVVM(Model-View-ViewModel)是一种软件设计模式,由微软WPF(用于替代WinForm,以前就是用这个技术开发桌面应用程序的)和Silverlight(类似于JavaApplet,简单点说就是在浏览器上运行WPF)的架构师KenCooper和TedPeters开发,是一种简化用户界面的事件驱动编程方式。由JohnGossman(同样也是WPF和Sliverlight的架构师)与2005年在他的

    2022年5月4日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号