开发者社区> 晓之以理的喵~~> 正文

SQL 中delete与truncate的区别

简介: SQL 中delete与truncate的区别
+关注继续查看

背景

前段时间,运维那边反馈说,我们开发这边的调度任务,老是卡死他们的数据库备份,要求我们自己核查。经过校验查看 ,发现是清空数据表的时候导致的问题,原来我们采用的是delete,后来重新替换成truncate的形式就解决了这个问题。然后梳理了一下delete与truncate的区别以及优缺点。enjoy~~

1,delete

语法:delete from 表名;

2,truncate

语法:truncate table 表名;

3,相同点

delete与truncate都是用来删除表数据

4,区别

(1)delete是DML命令,truncate是DDL命令。
(2)truncate可以删除整张表的数据而不维护表的完整性,delete可以删除指定的数据, delete不能绕过完整性强制机制。
(3)delete语句支持where条件的筛选和过滤,删除特定的数据;truncate 不支持where条件的筛选,只可以清空全表的数据。
(4)delete语句是行级锁定,表中的每一行都被锁定以进行删除;truncat语句是表级锁定,锁定了整个表以删除所有记录。
(5)delete命令维护日志,执行速度较慢,但涉及到日志记录,可以回滚恢复;truncate命令在事务日志中维护最少的日志记录,执行速度较快,效率高,但是无法回滚恢复。
(6)delete命令比truncate命令使用更多的事务空间。delete删除表中数据时,涉及到事务处理:回退(缓存)、提交、撤退;truncate删除数据是删除缓存,不涉及缓存事务处理。
(7)delete命令可以与索引视图一起使用;而,truncate命令不能与索引视图一起使用。

5,应用场景

(1)在业务中,无论是使用delete语句还是使用truncate语句,都要考虑数据的备份。
(2)根据一定的业务条件删除数据时、且数据量、性能可控的情况下,可以考虑使用delete语句。
(3)在业务中需要删除大批量数据时,同时要求速度快,效率高并且无需撤销时,可以使用truncate语句。
(4)在业务中考虑事务提交、撤销的管理机制时,使用delete语句。

总结

在我们的工作中,需要根据不同的业务场景,去选择合适的删除语句,并且在使用删除语句的时候,要做好数据的备份,以防数据丢失。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SQL DELETE 语句
SQL DELETE 语句
28 0
sql数据库中的 delete 与drop的区别
sql数据库中的 delete 与drop的区别
48 0
软件测试mysql面试题:定义SQL Delete语句。
软件测试mysql面试题:定义SQL Delete语句。
32 0
【sql语句基础】——删(delete) /改(update)
【sql语句基础】——删(delete) /改(update)
35 0
零基础自学SQL课程 | DELETE 删除语句
今天是SQL课程的第十课。 讲讲DELETE 删除语句,用来删除表中的一条或多条记录。 基本语法:
58 0
Influx Sql系列教程七:delete 删除数据
前面介绍了使用insert实现新增和修改记录的使用姿势,接下来我们看一下另外一个简单的使用方式,如何删除数据
195 0
Mysql常用sql语句(24)- delete 删除数据
Mysql常用sql语句(24)- delete 删除数据
50 0
+关注
晓之以理的喵~~
好好学习,天天向上!
文章
问答
文章排行榜
最热
最新
相关电子书
更多
用SQL做数据分析
立即下载
阿里云流计算 Flink SQL 核心功能解密
立即下载
Comparison of Spark SQL with Hive
立即下载