栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 其他

mysql删除大数据量表数据

其他 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mysql删除大数据量表数据

背景:生产环境服务器磁盘空间不足,调查发现mysql容器占用过大,进一步排查发现存在一个非生产应用需求表占用过百G磁盘空间。确认目标处理为留表不留数据且表中有亿级数据。

问题:删除该类数据可以drop、truncate、delete,选择哪一个可以及时释放表空间且影响最小?

过程:

        >目前最好的选择是truncate,但是针对mysql并不熟悉,对使用truncate后是否能释放表空间产生了疑惑。

        >百度,存在一个说法“当使用 truncate table tablename;如果你使用过的表的引擎是myisam那么清空以后会释放掉磁盘空间,而 innoDB 不会释放磁盘空间”。而我们使用的正是InnoDB引擎,存疑了...

        >本地新建测试表,导入部分数据使用truncate table 观测发现表空间被成功释放。

结论:truncate table 无论表引擎为InnoDB还是myisam都会立即释放表空间。(针对问题的结论,不做删除表的唯一性引导)

延展:

        >同时验证了一下delete from table [table_name],InnoDB下不会释放表空间,myisam下会立即释放表空间;但是如果是delete from table [table_name] where 带上条件后无论是哪种引擎都不会释放表空间。

        >学习了一下对于mysql InnDB使用delete后可以使用OPTIMIZE TABLE,可以重新组织表数据和相关索引数据的物理存储空间,减少存储空间并提高I/O访问效率。但是会造成一定的表阻塞锁表,生产环境下注意避开业务时间。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/279582.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号