快速删除mysql表中所有数据-TRUNCATE TABLE

文章目录


前言

在 MySQL 中,TRUNCATE TABLE 是一种用于快速清空表数据的命令,属于 DDL(数据定义语言) 操作,而不是 DML(数据操作语言)。它的执行效率通常比 DELETE 更高,因为它不是逐行删除,而是直接释放数据页并重新创建表结构。

用法

语法结构:

sql 复制代码
TRUNCATE TABLE table_name;

当我们需要将大数据量的数据库表中所有数据全部删除时,此时如果使用delete执行时间会非常慢,使用TRUNCATE TABLE table_name命令快速清空数据库表

与DELETE的区别

  • DELETE:属于 DML(数据操纵语言),是有条件的删除数据行,本质是 "逐行删除",可以通过 WHERE 子句指定删除范围,也可以不加 WHERE 删除全表数据。
  • TRUNCATE TABLE:属于 DDL(数据定义语言),是清空整张表,本质是 "重置表"------ 它会删除表中所有数据,重置自增列(如 AUTO_INCREMENT),并释放数据占用的存储空间。

适用场景

用 DELETE:

  1. 需要删除部分数据(如删除某个用户的记录);
  2. 需要触发删除触发器;
  3. 操作后可能需要回滚(如事务内操作)。

用 TRUNCATE TABLE:

  1. 需要快速清空整张表(如测试环境重置数据);
  2. 需要重置自增列;
  3. 对执行效率要求高(数据量越大,TRUNCATE 优势越明显)。

总结

DELETE 是逐行删除,可带 WHERE 条件,支持事务回滚,并触发触发器。

TRUNCATE 删除所有数据,不支持条件过滤,不可回滚,且速度更快。


相关推荐
2301_809204706 分钟前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全7 分钟前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap
阿坤带你走近大数据31 分钟前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
yoyo_zzm38 分钟前
Laravel8.x新特性全解析
数据库·nginx
码界奇点1 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
我科绝伦(Huanhuan Zhou)2 小时前
探索技术世界:我的GitHub数据库工具宝库
数据库·github
猫的玖月2 小时前
(一)MY SQL概述
数据库·sql
脑子进水养啥鱼?3 小时前
PostgreSQL .history 文件
数据库·postgresql
倔强的石头_3 小时前
5 个真实案例带你避坑:DolphinDB 实时写入、流订阅与高可用调优
数据库
虹科网络安全3 小时前
艾体宝新闻|Redis 月度更新速览:2026 年 3 月
数据库·redis·缓存