MySQL中RUNCATE、DELETE、DROP 的基本介绍

TRUNCATE、DELETE、DROP 的基本介绍

TRUNCATE

TRUNCATE 是一种 DDL(数据定义语言)操作,用于快速清空表中的所有数据,但保留表结构(如列、约束、索引等)。执行后,表的自增计数器会重置,且操作无法回滚(除非在事务中且数据库支持)。

DELETE

DELETE 是 DML(数据操纵语言)操作,用于删除表中的指定行或所有行。支持 WHERE 子句筛选数据,操作可回滚(通过事务),但不会重置自增计数器。DELETE 会逐行删除数据,触发触发器。

DROP

DROP 是 DDL 操作,用于完全删除表(包括表结构、数据、索引、权限等)。执行后表不可恢复,空间立即释放,且不触发触发器。


三者的主要区别

  1. 操作类型

    • TRUNCATE 和 DROP 是 DDL 操作。
    • DELETE 是 DML 操作。
  2. 功能范围

    • TRUNCATE 仅清空数据,保留表结构。
    • DELETE 可删除部分或全部数据,保留表结构。
    • DROP 彻底删除表及其所有关联对象。
  3. 事务与回滚

    • TRUNCATE 在大多数数据库中不可回滚(但 MySQL 若在事务中执行可回滚)。
    • DELETE 支持事务,可回滚。
    • DROP 不可回滚。
  4. 性能

    • TRUNCATE 比 DELETE 更快(不记录逐行删除日志,直接释放数据页)。
    • DROP 最快(直接删除元数据和文件)。
  5. 触发器与约束

    • TRUNCATE 不触发 DELETE 触发器。
    • DELETE 会触发触发器并检查约束(如外键)。
    • DROP 不触发任何触发器。
  6. 自增字段

    • TRUNCATE 重置自增计数器。
    • DELETE 保留自增计数器的当前值。

使用场景示例

TRUNCATE

需要快速清空一个大表且无需保留自增计数:

sql 复制代码
TRUNCATE TABLE employees;

DELETE

删除符合条件的数据或需要事务控制时:

sql 复制代码
DELETE FROM employees WHERE department = 'HR';

DROP

彻底删除不再需要的表:

sql 复制代码
DROP TABLE temp_data;

注意事项

  • 权限要求:TRUNCATE 和 DROP 通常需要更高权限(如 DDL 权限)。
  • 外键约束:TRUNCATE 可能因外键约束失败(需先禁用约束或使用 DELETE)。
  • 备份:执行 DROP 前务必确认数据已备份。
相关推荐
NineData1 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师3 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石7 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript