您现在的位置是:亿华云 > 知识
Truncate、Delete和Drop的六大区别!你知道几个?
亿华云2025-10-04 07:57:51【知识】7人已围观
简介在 MySQL 中,使用 truncate、delete 和 drop 都可以实现表删除,但它们 3 个的使用场景和执行效果完全不同,接下来我们来盘点一下。truncate、delete、drop区别
在 MySQL 中,的大区道使用 truncate、别知delete 和 drop 都可以实现表删除,的大区道但它们 3 个的别知使用场景和执行效果完全不同,接下来我们来盘点一下。的大区道
truncate、别知delete、的大区道drop区别概述它们 3 个的别知区别如下表所示:
区别点
drop
truncate
delete
执行速度
快
较快
慢
命令分类
DDL(数据定义语言)
DDL(数据定义语言)
DML(数据操作语言)
删除对象
删除整张表和表结构,以及表的的大区道索引、约束和触发器。别知
只删除表数据,的大区道表的别知结构、索引、的大区道约束等会被保留。别知
只删除表的的大区道全部或部分数据,表结构、索引、约束等会被保留。
删除条件(where)
不能用
不能用
可使用
回滚
不可回滚
不可回滚
可回滚
自增初始值
-
重置
不重置
接下来我们用案例来演示一下它们的区别。
准备工作正式开始之前,网站模板我们先来创建一个用户表和用户测试数据,方便后续演示使用:
CREATE TABLE `userinfo` (
`id` int(11) NOT NULL AUTO_INCREMENT comment 编号,
`name` varchar(250) NOT NULL comment 姓名 unique,
`balance` decimal(10,2) NOT NULL DEFAULT 0.00 comment 账户余额,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
insert into userinfo values(1,张三,1000),(2,李四,500),(3,王五,2000),(4,李六,500);创建的表结构和数据如下图所示:
delete 和 truncate 只删除表数据,不删除表结构,其中 delete 删除之后的结果如下:
我们先将表还原到初始状态,再使用 truncate 执行删除操作,执行结果如下图所示:
把表还原到初始状态,执行 drop 删除语句,执行结果如下图所示:
从上述结果可以看出,delete 和 truncate 只删除表数据,而 drop 把表结构和表数据都删除了。
2.删除条件支持不同truncate 和 drop 不支持添加 where 条件,而 delete 支持 where 条件,如下图所示:
truncate、delete 和 drop 所属 SQL 分类不同,SQL 分为以下 3 类:
DDL【DataDefinitionLanguage】数据定义语言,用来维护存储数据的结构代表指令: create、drop、alter、truncate。DML【DataManipulationLanguage】数据操纵语言,用来对数据进行操作代表指令:insert,delete,update,DML 中又单独分了一个 DQL,数据查询语言,代表指令是 select。DCL【DataControlLanguage】数据控制语言,主要负责权限管理和事务代表指令:grant,revoke,服务器托管commit。其中 delete 属于 DML,而 truncate 和 drop 属于 DDL。
PS:truncate 是先复制一个新的表结构,再把原有旧表结构和数据一起删除,所以它属于数据定义语言 DDL,而非数据操纵语言 DML。
4.回滚支持不同delete 属于 DML 支持事务回滚操作,而 truncate 和 drop 属于 DDL,执行之后立马生效,且数据是不可恢复的,接下来我们来验证一下。首先先将 MySQL 的自动事务提交关闭,自动事务提交的默认值是“ON”也就是开启了自动提交,如下图所示:
我们使用以下命令将自动提交(事务)关掉:
set autocommit=off;再次查询事务自动提交的设置结果如下:
接下来我们演示一下 delete 的回滚操作,如下图所示:
从上述结果可以看出 delete 之后是可以进行恢复(回滚)的,而 truncate 和 drop 之后是不能回滚的,各位老铁可以使用相同的方法自行测试一下后两种 SQL 的亿华云计算执行。
5.自增初始化不同delete 不会重置自增字段的初始值,如下图所示:
而 truncate 会重置自增字段的初始值,如下图所示:
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 语句。很赞哦!(2531)
相关文章
- Status、Creation Date、Expiration Date
- 海外终端会选择什么域名?你不知道的海外终端域名有哪些?
- 为什么com域名总是处于不败地位?什么原因?
- ooo是哪国域名?如何看待ooo域名后缀?
- 2、根据用户基础选择访问提供程序。由于互联问题的存在,接入商的选择也非常重要,如果用户群主要在联通,尽量选择联通接入较好的接入商,如果用户群主要在电信,那么选择电信接入较好的接入商。如果用户组位于国家/地区,则选择更好的访问提供程序进行交互。
- 新手发生了域名争议怎么办?域名争议解决办法有哪些?
- ooo是哪国域名?如何看待ooo域名后缀?
- 新手认知中的pw域名是怎样的?大家怎么看待pw域名?
- 3、查看排名
- wang域名值得购买吗?新手要了解wang域名哪些?