mysql常用SQL

清空数据表

在 MySQL 中,清空数据表的命令主要有两种:TRUNCATE TABLEDELETE。它们虽然都能删除数据,但在底层机制和使用场景上有很大的区别。

1. 快速清空整张表:TRUNCATE TABLE

如果你需要快速删除表内的所有数据,并且不需要保留自增ID的计数,推荐使用此命令。

  • 基本语法TRUNCATE TABLE 表名;TABLE 关键字可以省略)
  • 特点
    • 执行极快:它属于 DDL(数据定义语言)操作,本质上是直接删除并重新创建一张空表,不记录单行删除的日志。
    • 重置自增ID:表中的自增主键(AUTO_INCREMENT)会被重置为初始值(通常是1)。
    • 不可回滚:操作会隐式提交,执行后无法通过事务回滚恢复数据。
    • 不触发触发器:不会激活表上定义的 DELETE 触发器。

2. 按条件或安全删除:DELETE

如果你需要删除部分数据 ,或者希望操作具备可回滚性,应使用此命令。

  • 基本语法DELETE FROM 表名;(不带 WHERE 条件时清空全表)
  • 特点
    • 支持条件删除 :可以通过 WHERE 子句只删除满足特定条件的记录。
    • 事务安全:属于 DML(数据操纵语言),可以在事务中执行,支持回滚(ROLLBACK)。
    • 保留自增ID:删除数据后,自增主键的计数不会重置,新插入的数据会继续使用之前的自增值。
    • 触发触发器:删除操作会正常触发表上的 DELETE 触发器。

⚡️ 核心区别对比

为了让你更直观地了解两者的差异,可以参考下表:

对比项 TRUNCATE TABLE DELETE FROM
操作类型 DDL(数据定义语言) DML(数据操纵语言)
执行速度 极快(直接重建表) 较慢(逐行删除)
WHERE条件 不支持(只能清空全表) 支持(可删除指定行)
事务回滚 不可回滚 可回滚
自增ID 重置为初始值(如1) 不重置,继续累加
触发器 不触发 会触发

💡 避坑与安全建议

  1. 外键约束 :如果表被其他表的外键引用,TRUNCATE 通常会执行失败。此时需要先禁用外键检查或改用 DELETE
  2. 生产环境慎用TRUNCATEDELETE 都是高危操作。在生产环境中执行前,务必先备份重要数据,并仔细确认 WHERE 条件(如果使用 DELETE),以免造成不可挽回的数据丢失。
  3. 大表删除 :对于千万级以上的大表,直接使用 DELETE 可能会导致数据库锁表或性能骤降,建议采用分批删除的策略。
相关推荐
爱喝水的鱼丶12 小时前
SAP-ABAP:变量、常量、结构与内表声明(10篇博客合集) 第八篇:复杂业务场景下的声明组合:结构嵌套内表、内表包含结构的实现方法
运维·数据库·学习·算法·sap·abap
这个DBA有点耶12 小时前
集中式 vs 分布式:2026数据库选型决策树
数据库·分布式·决策树
Daydream.V12 小时前
SQL Server 超详细入门教程
sql·sql server
鸽芷咕12 小时前
KingbaseES系统视图与Hints调优:从诊断到性能优化的进阶之路
数据库·oracle·性能优化
Pocker_Spades_A12 小时前
没公网IP怎么远程连数据库?PostgreSQL + cpolar,在任何网络环境下都能连上
网络·数据库·tcp/ip
数据与后端架构提升之路12 小时前
RAG 实战指南:深入浅出向量数据库 Milvus
数据库·milvus
风间琉璃"""12 小时前
Reverse5
数据库
一只fish12 小时前
Oracle官方文档翻译《Database Concepts 26ai》第11章-服务器端编程
数据库·oracle
一只fish12 小时前
Oracle官方文档翻译《Database Concepts 26ai》第13章-事务
数据库·oracle