dbaplus社群 18小时前
新来个技术总监:发现谁再用 delete 删数据直接开除!
index_new5.html
../../../zaker_core/zaker_tpl_static/wap/tpl_guoji1.html

 

文章探讨了MySQL数据库中删除数据的不同方式,特别是DELETE、TRUNCATE和DROP的区别。强调了在线上环境中谨慎使用DELETE的原因,因为其可能导致数据无法恢复、索引失效、表空间浪费以及数据不一致等问题。文章建议在删除数据前进行备份,并养成良好的数据库运维习惯,以避免潜在的数据丢失和系统问题。

⚠️ DELETE操作的本质:DELETE属于DML操作,仅标记数据为已删除,不立即释放磁盘空间,且会记录在redo和undo表空间中,以便回滚和重做,这可能导致表空间浪费和性能下降。

🔥 TRUNCATE与DROP的区别:TRUNCATE是DDL操作,速度快,清空表并重置auto_increment值,而DROP直接删除表结构,两者均立即释放磁盘空间,但DROP无法恢复,需谨慎操作。

💡 不推荐DELETE的原因:DELETE可能导致数据无法恢复、索引失效、表空间浪费和数据不一致。特别是在存在外键关联时,DELETE可能破坏数据完整性,因此建议谨慎使用。

✅ 最佳实践:在进行数据删除操作前,务必进行数据备份,养成良好的数据库运维习惯,以减少误操作带来的风险,确保数据的安全性和完整性。

2025-06-16 07:15 广东

为什么 MySQL 不建议使用 delete 删除数据?


源于一个读者实际工作中遇到的问题,老大一直强调线上不允许用 delete 来删除 Mysql 数据库的数据(有一次发飚了,说如果再发现谁这样操作直接开除)。为什么 MySQL 不建议使用 delete 删除数据呢?


这就得从以下几方面说起!!!


MySQL 是一种关系型数据库管理系统,它的数据存储是基于磁盘上的文件系统实现的。MySQL 将数据存储在表中,每个表由一系列的行和列组成。每一行表示一个记录,每一列表示一个字段。表的结构由其列名、数据类型、索引等信息组成。


MySQL 的数据存储采用了多种技术来优化性能和存储效率。以下是 MySQL 数据存储的一些关键特性。


存储引擎


MySQL 支持多种不同的存储引擎,每种引擎都有不同的性能和存储特性。常见的存储引擎有 InnoDB、MyISAM、Memory 等。不同的存储引擎支持不同的数据存储方式,如 B树索引、哈希索引、全文索引等。


数据页


MySQL 使用数据页来管理存储在磁盘上的数据。数据页是 MySQL 存储引擎中最基本的存储单元,通常情况下每个数据页的大小为 16KB。数据页包含多个记录,每个记录对应一行数据。


索引


MySQL 使用索引来优化数据的检索效率。索引是一种特殊的数据结构,它能够快速地查找表中的数据。MySQL 支持多种类型的索引,如 B 树索引、哈希索引、全文索引等。B 树索引是 MySQL 中最常用的索引类型,它能够快速地查找表中的数据。


事务


MySQL 支持事务,事务可以保证数据的一致性、可靠性和安全性。MySQL 的事务是基于 ACID 模型实现的,它能够确保数据在事务中的操作要么全部成功,要么全部回滚。事务的支持使得 MySQL 在多用户并发访问时能够保证数据的完整性和一致性。


总之,MySQL 的数据存储基于磁盘上的文件系统实现,采用多种技术来优化性能和存储效率,如存储引擎、数据页、索引、事务等。这些特性使得 MySQL 成为一种高性能、可靠和安全的关系型数据库管理系统。


一、MySQL删除数据的方式都有哪些?


咱们常用的三种删除方式:通过 delete、truncate、drop 关键字进行删除;这三种都可以用来删除数据,但场景不同。


执行速度 :drop > truncate >> DELETE


从原理上理解


1)DELETE


DELETE from TABLE_NAME where xxx


DELETE 属于数据库DML操作语言,只删除数据不删除表的结构,会走事务,执行时会触发trigger;


在 InnoDB 中,DELETE其实并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记为已删除,因此 delete 删除表中的数据时,表文件在磁盘上所占空间不会变小,存储空间不会被释放,只是把删除的数据行设置为不可见。**虽然未释放磁盘空间,但是下次插入数据的时候,仍然可以重用这部分空间(重用 → 覆盖)。


DELETE执行时,会先将所删除数据缓存到rollback segement中,事务commit之后生效;


delete from table_name删除表的全部数据,对于MyISAM 会立刻释放磁盘空间,InnoDB 不会释放磁盘空间;


对于delete from table_name where xxx 带条件的删除, 不管是InnoDB还是MyISAM都不会释放磁盘空间;


delete操作以后使用 optimize table table_name 会立刻释放磁盘空间。不管是InnoDB还是MyISAM 。所以要想达到释放磁盘空间的目的,delete以后执行optimize table 操作。


示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2)


select concat(round(sum(DATA_LENGTH/1024/1024),2),'M') as table_size 

   from information_schema.tables 

      where table_schema='csjdemo' AND table_name='demo2';



然后执行空间优化语句,以及执行后的表Size变化:


optimize table demo2



再看看这张表的大小,就只剩下表结构size了。



delete 操作是一行一行执行删除的,并且同时将该行的的删除操作日志记录在redo和undo 表空间中以便进行回滚(rollback)和重做操作,生成的大量日志也会占用磁盘空间 。


2)drop


Drop table Tablename


属于数据库DDL定义语言,同Truncate,执行后立即生效,无法找回 。


drop table table_name 立刻释放磁盘空间 ,不管是 InnoDB 和 MyISAM; drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);  依赖于该表的存储过程/函数将保留,但是变为 invalid 状态。


小心使用 drop ,要删表跑路的兄弟,请在订票成功后在执行操作!


可以这么理解,一本书,delete是把目录撕了,truncate是把书的内容撕下来烧了,drop是把书烧了


3)truncate


属于数据库DDL定义语言,不走事务 ,原数据不放到 rollback segment 中,操作不触发 trigger。执行后立即生效,无法找回 !


truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。truncate table其实有点类似于drop table 然后creat,只不过这个create table 的过程做了优化,比如表结构文件之前已经有了等等。所以速度上应该是接近drop table的速度;


truncate 能够快速清空一个表。并且重置auto_increment的值。


但对于不同的类型存储引擎需要注意的地方是:



小心使用 truncate,尤其没有备份的时候,如果误删除线上的表,记得及时跑路。


二、为什么不建议使用DELETE 删除数据


了解上面的一些原理之后,可以知道!



在使用DELETE操作删除数据时,如果没有事先备份数据,一旦误操作就会导致数据无法恢复。因此,在进行任何数据操作之前,最好先备份数据,以便在出现错误时可以轻松地恢复数据。



如果在删除数据时表中存在外键关联,使用DELETE操作可能会导致其他表中的数据不一致。例如,如果一个表有一个外键,指向另一个表中的一行,如果从主表中删除行而不更新外键引用,则外键引用将成为无效引用。这可能会导致查询时出现错误,或者在更新时导致数据不一致。


三、总结


在工作当中执行数据库删除的时候一定要慎重再慎重,建议每次进行数据删除的使用最好数据表的备份工作,这样就会大大减少你删除跑路的几率。很多时候不要过于相信自己的动手能力,老虎还有打盹的时候,万一手滑了呢。尽可能养成好的数据库运维习惯,这样会让自己少跌跟头,你的事业才会更加顺利。



来源丨网址:https://blog.csdn.net/weixin_74412978/article/details/144914524

dbaplus社群欢迎广大技术人员投稿,投稿邮箱:editor@dbaplus.cn

阅读原文

跳转微信打开

Fish AI Reader

Fish AI Reader

AI辅助创作,多种专业模板,深度分析,高质量内容生成。从观点提取到深度思考,FishAI为您提供全方位的创作支持。新版本引入自定义参数,让您的创作更加个性化和精准。

FishAI

FishAI

鱼阅,AI 时代的下一个智能信息助手,助你摆脱信息焦虑

联系邮箱 441953276@qq.com

相关标签

MySQL DELETE TRUNCATE DROP 数据库运维
相关文章