Truncate、Delete和Drop的六大区别!你知道几个?

网站建设4年前发布
26 0 0

在 MySQL  中,使用 truncate、delete 和 drop 都可以实现表删除,但它们 3 个的使用场景和执行效果完全不同,接下来我们来盘点一下。,它们 3 个的区别如下表所示:,接下来我们用案例来演示一下它们的区别。,正式开始之前,我们先来创建一个用户表和用户测试数据,方便后续演示使用:,创建的表结构和数据如下图所示:,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”也就是开启了自动提交,如下图所示:,我们使用以下命令将自动提交(事务)关掉:,再次查询事务自动提交的设置结果如下:,接下来我们演示一下 delete 的回滚操作,如下图所示:,从上述结果可以看出 delete 之后是可以进行恢复(回滚)的,而 truncate 和 drop 之后是不能回滚的,各位老铁可以使用相同的方法自行测试一下后两种 SQL 的执行。,delete 不会重置自增字段的初始值,如下图所示:,而 truncate 会重置自增字段的初始值,如下图所示:,delete 是逐行执行的,并且在执行时会把操作日志记录下来,以备日后回滚使用,所以 delete 的执行速度是比较慢的;而 truncate 的操作是先复制一个新的表结构,再把原先的表整体删除,所以它的执行速度居中,而 drop 的执行速度最快。,truncate、drop 和 delete 的区别主要有以下 6 点:

© 版权声明

相关文章