玩家时代主管2面试突击58:truncate、delete和drop的6大区别

在 MySQL 中,玩家时代主管QQ1758022965使用 truncate、delete 和 drop 都可以实现表删除,但它们 3 个的使用场景和执行效果完全不同,接下来我们来盘点一下。truncate、delete、drop区别概述它们 3 个的区别如下表所示:
区别点droptruncatedelete执行速度快较快慢命令分类DDL(数据定义语言)DDL(数据定义语言)DML(数据操作语言)删除对象删除整张表和表结构,以及表的索引、约束和触发器。只删除表数据,表的结构、索引、约束等会被保留。只删除表的全部或部分数据,表结构、索引、约束等会被保留。删除条件(where)不能用不能用可使用回滚不可回滚不可回滚可回滚自增初始值-重置不重置
接下来我们用案例来演示一下它们的区别。准备工作正式开始之前,我们先来创建一个用户表和用户测试数据,方便后续演示使用:CREATETABLE`userinfo` (  `id`int(11)NOTNULLAUTO_INCREMENT comment'编号',  `name`varchar(250)NOTNULLcomment'姓名'unique,  `balance`decimal(10,2)NOTNULLDEFAULT'0.00'comment'账户余额',PRIMARYKEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=3DEFAULTCHARSET=utf8;insertintouserinfovalues(1,'张三',1000),(2,'李四',500),(3,'王五',2000),(4,'李六',500);创建的表结构和数据如下图所示:
1.删除对象不同delete 和 truncate 只删除表数据,不删除表结构,其中 delete 删除之后的结果如下:

我们先将表还原到初始状态,再使用 truncate 执行删除操作,执行结果如下图所示:

把表还原到初始状态,执行 drop 删除语句,执行结果如下图所示:

从上述结果可以看出,delete 和 truncate 只删除表数据,而 drop 把表结构和表数据都删除了。2.删除条件支持不同truncate 和 drop 不支持添加 where 条件,而 delete 支持 where 条件,如下图所示:
3.命令分类不同truncate、delete 和 drop 所属 SQL 分类不同,SQL 分为以下 3 类:
DDL【Data Definition Language】数据定义语言,用来维护存储数据的结构代表指令: create、drop、alter、truncate。

DML【Data Manipulation Language】数据操纵语言,用来对数据进行操作代表指令:insert,delete,update,DML 中又单独分了一个 DQL,数据查询语言,代表指令是 select。

DCL【Data Control Language】数据控制语言,主要负责权限管理和事务代表指令:grant,revoke,commit。
其中 delete 属于 DML,而 truncate 和 drop 属于 DDL。PS:truncate 是先复制一个新的表结构,再把原有旧表结构和数据一起删除,所以它属于数据定义语言 DDL,而非数据操纵语言 DML。4.回滚支持不同delete 属于 DML 支持事务回滚操作,而 truncate 和 drop 属于 DDL,执行之后立马生效,且数据是不可恢复的,接下来我们来验证一下。
首先先将 MySQL 的自动事务提交关闭,自动事务提交的默认值是“ON”也就是开启了自动提交,如下图所示:

我们使用以下命令将自动提交(事务)关掉:setautocommit=off;再次查询事务自动提交的设置结果如下:

接下来我们演示一下 delete 的回滚操作,如下图所示:

从上述结果可以看出 delete 之后是可以进行恢复(回滚)的,而 truncate 和 drop 之后是不能回滚的,各位老铁可以使用相同的方法自行测试一下后两种 SQL 的执行。5.自增初始化不同delete 不会重置自增字段的初始值,如下图所示:

而 truncate 会重置自增字段的初始值,如下图所示:
6.执行速度不同delete 是逐行执行的,并且在执行时会把操作日志记录下来,以备日后回滚使用,所以 delete 的执行速度是比较慢的;而 truncate 的操作是先复制一个新的表结构,再把原先的表整体删除,所以它的执行速度居中,而 drop 的执行速度最快。总结truncate、drop 和 delete 的区别主要有以下 6 点:
执行速度:drop > truncate > detele。

delete 和 truncate 只删除表数据,而 drop 会删除表数据和表结构以及表的索引、约束和触发器。

delete 可以加 where 条件实现部分数据删除,而 truncate 和 drop 不能加 where 条件是整体删除。

truncate 和 drop 是立即执行,且不能恢复;而 delete 会走事务,可以撤回和恢复。

truncate 会重置自增列为 1,而 delete 不会重置自增列。

truncate 和 drop 是 DDL 语句,而 delete 是 DML 语句。
是非审之于己,毁誉听之于人,得失安之于数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值