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 分钟前
SSM旅游资讯信息服务系统的实现04s3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·旅游·ssm 框架·旅游资讯系统·会员管理
3***31217 分钟前
初识MySQL · 库的操作
数据库·mysql
合作小小程序员小小店7 分钟前
网页开发,在线%新版本旅游管理%系统,基于eclipse,html,css,jquery,servlet,jsp,mysql数据库
java·数据库·eclipse·html·intellij-idea·旅游·jsp
anod7 分钟前
奇怪的mysql时区问题
数据库·mysql·eclipse
鲸说MySQL18 分钟前
MySQL表文件损坏
数据库·mysql
a***592623 分钟前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
0***v77731 分钟前
使用Dify访问数据库(mysql)
数据库·mysql
愚戏师42 分钟前
MySQL 数据导出
数据库·笔记·mysql
倔强的石头_1 小时前
openGauss向量数据库:引领AI时代数据智能新纪元
数据库
愚戏师1 小时前
MySQL SQL 注入
数据库·sql·mysql