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 前务必确认数据已备份。
相关推荐
李白客4 分钟前
分布式交易型数据库:数字时代交易系统的“定海神针“
数据库·分布式
曹牧7 分钟前
Oracle:CHR的典型用法
数据库·oracle
我是一颗柠檬15 分钟前
【Java项目技术亮点】全链路分层限流:从网关到数据库的多层防护体系
java·开发语言·数据库
xhtdj25 分钟前
技术采用曲线回望二十年
运维·数据库·人工智能·clickhouse·动态规划
油炸自行车1 小时前
【bug】Qt 6 Q_NAMESPACE 跨 DLL 链接错误:LNK2019 无法解析 staticMetaObject
数据库·c++·qt·bug·link2019·q_namespace_exp·namespaceexport
Arvin.Angela1 小时前
MySQL安装及运行环境配置
数据库·mysql·adb
程序员小羊!1 小时前
16 JAVA MySQL 8.0
java·开发语言·mysql
2301_773643621 小时前
MySQLmha
mysql
Dovis(誓平步青云)1 小时前
《QT学习第五篇:QSS美化界面与API绘图》
开发语言·数据库·qt·学习·时序数据库·开源智能体
焦虑的说说1 小时前
mysql深分页性能瓶颈根源分析
数据库·mysql