在MySQL中 Truncate Delect Drop 的区别


面试问题:

--

-- 请详细描述MySQL中TRUNCATE TABLE、DELETE FROM和DROP TABLE三个命令的区别,包括它们的作用、性能影响、事务日志的生成以及对表结构和触发器的影响。

--

-- 回答:

--

-- 在MySQL中,TRUNCATE TABLE、DELETE FROM和DROP TABLE是三个用于管理数据库表的重要命令,它们之间在多个方面存在显著差异:

--

-- 作用:

-- TRUNCATE TABLE:此命令用于删除表中的所有行,但保留表本身的结构(包括索引、列定义等)和属性。它不激活DELETE触发器,并且操作通常不能被回滚。

-- DELETE FROM:该命令用于根据条件删除表中的一行或多行。如果没有指定条件,则删除所有行。DELETE会激活表的DELETE触发器,并且操作可以被回滚。

-- DROP TABLE:此命令用于删除整个表及其所有内容,包括结构、索引、数据和权限等。一旦执行,表将不再存在于数据库中,且此操作通常也不能被回滚。

-- 性能影响:

-- TRUNCATE TABLE:通常比DELETE更快,因为它不逐行删除数据,而是重置表并释放空间。它产生的日志较少,因为它不记录每行删除的详细日志。

-- DELETE FROM:可能相对较慢,尤其是当删除大量行且启用了事务和回滚功能时。它会逐行删除数据,并可能记录每行删除的日志。

-- DROP TABLE:在删除整个表时,通常比DELETE或TRUNCATE更快,因为它不涉及逐行处理。

-- 事务日志的生成:

-- TRUNCATE TABLE:通常产生的日志较少,因为它不逐行删除数据,而是直接重置表。

-- DELETE FROM:会记录详细的日志,以便在需要时可以回滚操作。

-- DROP TABLE:记录的是表删除的操作,而不是行级别的删除。

-- 对表结构和触发器的影响:

-- TRUNCATE TABLE:保留表结构,但不激活DELETE触发器。

-- DELETE FROM:不改变表结构,但会激活DELETE触发器(如果已定义)。

-- DROP TABLE:删除整个表,包括其结构、索引和触发器。

-- -- 综上所述,选择哪个命令取决于具体的需求和场景。如果需要快速清空表中的所有数据而不保留事务日志,且不关心触发器,则TRUNCATE TABLE是最佳选择。如果需要基于条件删除数据,并可能需要回滚操作,则DELETE FROM更适合。如果需要彻底删除整个表及其所有内容,则DROP TABLE是正确的选择。

在MySQL中 Truncate Delect Drop 的区别的更多相关文章

  1. oracle中delete、truncate、drop的区别

    oracle中delete.truncate.drop的区别 标签: deleteoracletable存储 2012-05-23 15:12 7674人阅读 评论(0) 收藏 举报  分类: ora ...

  2. 用count(*)还是count(列名) || Mysql中的count()与sum()区别

    Mysql中的count()与sum()区别   首先创建个表说明问题 CREATE TABLE `result` (   `name` varchar(20) default NULL,   `su ...

  3. (转)MySQL中In与Exists的区别

    背景:总结mysql相关的知识点. 如果A表有n条记录,那么exists查询就是将这n条记录逐条取出,然后判断n遍exists条件. select * from user where exists s ...

  4. MySQL中interactive_timeout和wait_timeout的区别【转】

    在用mysql客户端对数据库进行操作时,打开终端窗口,如果一段时间没有操作,再次操作时,常常会报如下错误: ERROR 2013 (HY000): Lost connection to MySQL s ...

  5. Mysql中函数和存储过程的区别

    Mysql中函数和存储过程的区别 存储过程: 1.       可以写sql语句 2.       inout,out构造返回值 3.       调用:call:存储过程名称 4.       可以 ...

  6. MySQL中truncate误操作后的数据恢复案例

    MySQL中truncate误操作后的数据恢复案例 这篇文章主要介绍了MySQL中truncate误操作后的数据恢复案例,主要是要从日志中定位到truncate操作的地方然后备份之前丢失的数据,需要的 ...

  7. mysql中in和exist的区别

    mysql中in和exists的区别 -- in写法select * from A where A.id in (select bid from  B ) and A.name in (select ...

  8. MySQL中 utf8与utf8mb4的区别

    MySQL中 utf8与utf8mb4的区别 一.简介 ​ MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode.好在 ...

  9. mysql中的delete , drop 和truncate 区别

    1.delete 和 truncate 仅仅删除表数据,drop 连表数据和表结构一起删除,打个比方,delete 是单杀,truncate 是团灭,drop 是把电脑摔了. 2.delete 是 D ...

  10. Mysql中truncate table和delete语句的区别

    Mysql中的truncate table和delete语句都可以删除表里面所有数据,但是在一些情况下有些不同! 例子: truncate table gag; (1)truncate table删除 ...

随机推荐

  1. 牛逼:一张900w的数据表,17s执行的SQL优化到300ms?

    转载自   https://mp.weixin.qq.com/s/ru_B1aI0YrpXeSl-J01sHQ

  2. 利用 Helm 在各类 Kubernetes 中安装 Rainbond

    利用 Helm 安装 Rainbond 好雨科技技术团队一直致力于让用户更方便的安装 Rainbond 这款产品. 不久前,我们刚刚推出了在一个容器中部署 Rainbond 的快速安装方式,这种方式覆 ...

  3. TensorRT环境配置(VS+opencv4.5)

    1 TensorRT下载 下载与TensorRT相匹配的CUDA和cuDNN版本:https://docs.nvidia.com/deeplearning/tensorrt/archives/tens ...

  4. uniapp 复选框全选(基于colorui组件)

    说明:本案例的样式基于colorui组件库 感兴趣的小伙伴可以看下教程 colorui组件库开发文档或者csdn的文档,顺便再分享下 colorui的群资源 html <checkbox-gro ...

  5. Qt-绘图设备

    1  简介 参考视频:https://www.bilibili.com/video/BV1XW411x7NU?p=40 Qt绘图设备有三种:QPixmap.QBitmap.QImage.QPictur ...

  6. CF1753

    CF1753 成功因为虚拟机炸了,重新写一遍此文. 都是没有保存的错. A. Make Nonzero Sum 由于 Note that it is not required to minimize ...

  7. 剑指Offer-56.删除链表中重复的结点(C++/Java)

    题目: 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处理后为 ...

  8. kettle从入门到精通 第四十九课 ETL之kettle 自定义插件01

    1.kettle插件是什么 kettle本身有足够多的转换或者job步骤,但是依然不能覆盖所有的业务场景,所以Kettle 自定义插件在有些独特的业务场景可以大显身手. Kettle的插件架构使得我们 ...

  9. EF MYSQL 出现:输入字符串的格式不正确

    实体类字段和数据库类型不一致. 比如:数据库是char类型字段,程序里声明为int.

  10. Vue学习:2.V标签综合2

    接上一篇... V标签综合使用:书架案例 功能: 实现列表的渲染和删除 思路: 使用 v-for 渲染数据列表,并在每个列表项内放置一个绑定了 del方法的"删除"按钮,点击按钮时 ...