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 前务必确认数据已备份。
相关推荐
廿一夏6 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim8 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室9 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)9 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜9 小时前
Java项目常用数据归档方式
mysql
YOU OU10 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng11 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen11 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室11 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿11 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试