在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. [C#] 禁用控制台关闭按钮

    禁用控制台关闭按钮 internal class Program { [DllImport("user32.dll", EntryPoint = "FindWindow& ...

  2. 鸿蒙极速入门(五)-路由管理(Router)

    页面路由指在应用程序中实现不同页面之间的跳转和数据传递.HarmonyOS提供了Router模块,通过不同的url地址,可以方便地进行页面路由,轻松地访问不同的页面. 一.基础使用 Router模块提 ...

  3. React 的 KeepAlive 探索

    什么是 KeepAlive? 用过 Vue 的童鞋都知道 Vue 官方自带了 Keep-Alive 组件,它能够使组件在切换时仍能保留原有的状态信息,并且有专门的生命周期方便去做额外的处理.该组件在很 ...

  4. ubuntu18.04最小化安装

    ubuntu 18.04虚拟机安装 镜像下载地址: https://releases.ubuntu.com/18.04/ubuntu-18.04.6-live-server-amd64.iso 创建虚 ...

  5. FlexBox 行间距

    问题背景 在Flex布局方式下, 父容器约定是换行的方式, 不足以容纳一行子元素的时候, 会单独进行折行, 那么折行的行间距如何处理呢? 解决办法 通过在子Item上面设置margin-top可以模拟 ...

  6. RTMP协议中的Chunk Stream ID (CID)的作用

    一.协议分层 RTMP包是以Message的结构封装的,结构如下所示: 1)Message Type ID在1-7的消息用于协议控制,这些消息一般是RTMP协议自身管理要使用的消息,用户一般情况下无需 ...

  7. 用C++ Qt实现类似Photoshop的钢笔工具

    因为工作上的需求,需要实现一个类似Photoshop里面的钢笔工具, 分析一下它的功能,包括: 1. 有两种点:节点和控制点,节点是构成图形的基本端点,控制点是影响贝塞尔曲线的系数. 2. 创建节点: ...

  8. LeetCode 221. Maximal Square 最大正方形(C++/Java)

    题目: Given a 2D binary matrix filled with 0's and 1's, find the largest square containing only 1's an ...

  9. Scrapy框架(五)--请求传参

    在某些情况下,我们爬取的数据不在同一个页面中,例如,我们爬取一个电影网站,电影的名称,评分在一级页面,而要爬取的其他电影详情在其二级子页面中. 这时我们就需要用到请求传参. 请求传参的使用场景 当我们 ...

  10. 模拟epoll的饥饿场景

    说明 一直听说epoll的饥饿场景,但是从未在实际环境中面对过,那么能不能模拟出来呢?实际的情况是怎样呢? 模拟步骤 基于epoll写一个简单的tcp echo server,将每次read返回的字节 ...