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 可能会导致数据库锁表或性能骤降,建议采用分批删除的策略。
相关推荐
嵌入式-老费2 分钟前
esp32开发与应用(看门狗测试)
java·开发语言·数据库
czhc11400756633 分钟前
615:代码细节
数据库
炘爚4 分钟前
Linux——MySQL
linux·mysql
知识分享小能手8 分钟前
Hadoop学习教程,从入门到精通, HBase 分布式数据库 — 完整知识点与案例代码(8)
数据库·hadoop·分布式
罗政10 分钟前
AI工作流实现Excel自动化+SQL,零 VBA ,零公式,电商订单分析案例 | DTBot
sql·自动化·excel
吴声子夜歌13 分钟前
SQL经典实例——处理数字
java·数据库·sql
NineData18 分钟前
日常巡检 Oracle 时,ChatDBA 怎么把会话、SQL 和等待事件一起看
数据库·sql·oracle·ninedata·故障排查·chatdba·实例巡检
海天一色y24 分钟前
深入理解 RAG 技术:从语义张量到向量数据库,Milvus 与 FAISS 全面对比
数据库·milvus·faiss
爱吃羊的老虎24 分钟前
【数据库】模块二:SQL 语句、高级特性与优化
数据库·oracle
Rain50924 分钟前
2.4. PostgreSQL 数据库连接与实战指南
前端·数据库·人工智能·后端·postgresql·数据分析