drop delete和truncate的区别?

操作性质差异

DELETE 是数据操作语言(DML),逐行删除数据,可触发触发器,支持条件筛选(WHERE子句)。
TRUNCATE 是数据定义语言(DDL),通过释放数据页直接清空表,不触发触发器,无法指定条件。

事务与日志记录

DELETE 操作会记录每行删除的日志,支持事务回滚(ROLLBACK)。
TRUNCATE 仅记录页释放日志,多数数据库(如Oracle、SQL Server)执行后不可回滚,但MySQL可通过事务回滚。

性能与资源占用

TRUNCATE 不扫描数据页,直接释放存储空间,速度远快于DELETE,尤其对大表明显。
DELETE 逐行操作并记录日志,占用更多事务日志资源和时间。

约束与索引处理

TRUNCATE 会重置自增列计数器(如MySQL的AUTO_INCREMENT),可能受外键约束限制(需先禁用约束)。
DELETE 保留自增列当前值,仅删除数据不影响表结构。

权限要求

DELETE 需要表上的DELETE权限。
TRUNCATE 通常需要更高权限(如DROP权限),因涉及表结构操作。

适用场景

需删除部分数据且可能回滚时使用DELETE

需快速清空全表且无需回滚时使用TRUNCATE

相关推荐
JH30737 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
m0_736919108 小时前
C++代码风格检查工具
开发语言·c++·算法
Coder_Boy_8 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
2501_944934738 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
invicinble8 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟8 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖8 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2301_763472469 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
TechWJ10 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
qq_124987075310 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计