首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >加速依赖于位列的MySql删除

加速依赖于位列的MySql删除
EN

Stack Overflow用户
提问于 2015-12-04 05:23:57
回答 1查看 160关注 0票数 2

我使用的是MySql 5.5.46,并且有一个包含位列的InnoDB表(名为“ENABLED”)。此列没有索引。该表有2600万行,所以可以理解的是,语句

代码语言:javascript
运行
复制
DELETE FROM my_table WHERE ENABLED = 0;

需要很长时间。我的问题是,有什么我可以做的(不升级MySQL,这目前不是一个选项),以加快运行这个查询所需的时间?我的“innodb_buffer_pool_size”变量设置如下:

代码语言:javascript
运行
复制
show variables like 'innodb_buffer_pool_size';
+-------------------------+-------------+
| Variable_name           | Value       |
+-------------------------+-------------+
| innodb_buffer_pool_size | 11674845184 |
+-------------------------+-------------+
EN

回答 1

Stack Overflow用户

发布于 2015-12-09 08:00:43

PRIMARY KEY的基础上,以1000为单位进行DELETE。参见。这篇文章详细介绍了分块的有效方法,以及如何处理PK中的差距。

(有了11 of的buffer_pool,我假设你有16 of的内存?)

通常,如果要选择的行数大于总行数的20%,则MySQL将执行表扫描,而不是使用索引。因此,几乎从来没有“标志”字段本身值得索引。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34076413

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档