它们 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 把表结构和表数据都删除了。
truncate 和 drop 不支持添加 where 条件,而 delete 支持 where 条件,如下图所示:
truncate、delete 和 drop 所属 SQL 分类不同,SQL 分为以下 3 类:
其中 delete 属于 DML,而 truncate 和 drop 属于 DDL。
PS:truncate 是先复制一个新的表结构,再把原有旧表结构和数据一起删除,所以它属于数据定义语言 DDL,而非数据操纵语言 DML。
delete 属于 DML 支持事务回滚操作,而 truncate 和 drop 属于 DDL,执行之后立马生效,且数据是不可恢复的,接下来我们来验证一下。首先先将 MySQL 的自动事务提交关闭,自动事务提交的默认值是“ON”也就是开启了自动提交,如下图所示:
我们使用以下命令将自动提交(事务)关掉:
set autocommit=off;
再次查询事务自动提交的设置结果如下:
接下来我们演示一下 delete 的回滚操作,如下图所示:
从上述结果可以看出 delete 之后是可以进行恢复(回滚)的,而 truncate 和 drop 之后是不能回滚的,各位老铁可以使用相同的方法自行测试一下后两种 SQL 的执行。
delete 不会重置自增字段的初始值,如下图所示:
而 truncate 会重置自增字段的初始值,如下图所示:
delete 是逐行执行的,并且在执行时会把操作日志记录下来,以备日后回滚使用,所以 delete 的执行速度是比较慢的;而 truncate 的操作是先复制一个新的表结构,再把原先的表整体删除,所以它的执行速度居中,而 drop 的执行速度最快。
truncate、drop 和 delete 的区别主要有以下 6 点:
文章标题:Truncate、Delete和Drop的六大区别!你知道几个?
网页URL:http://www.stwzsj.com/qtweb/news7/16957.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联