”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么我对change_event 表的“SELECT COUNT(*)”查询如此慢?

为什么我对change_event 表的“SELECT COUNT(*)”查询如此慢?

发布于2024-11-18
浏览:556

Why are my \

解决 MySQL 上缓慢的“SELECT COUNT(*)”查询

对change_event 表的查询,对超过特定change_event_id 的行进行计数,正在经历严重的延误。但为什么?让我们深入研究一下可能的原因。

揭秘InnoDB的行为

MySQL的InnoDB引擎使用聚集主键,这意味着主键与数据页中的行数据一起存储,而不是比单独的索引页。因此,范围扫描(例如您的扫描)需要扫描数据页中所有可能较宽的行。表的 xml_diff 列(一种 TEXT 数据类型)加剧了这一因素。

优化策略

为了加速查询,有两种方法值得考虑:

  • 优化表: 该命令将数据页重新组织成排序的顺序,可能会提高范围扫描的效率。
  • 创建附加索引:仅在change_event_id列上建立非主索引会在索引页中创建该列的副本。该索引的扫描速度比数据页快得多。创建后验证解释计划以确认其利用率。

其他提示:

要进一步提高性能,请考虑将 change_event_id 列更改为 bigint unsigned。此步骤可以防止负值,还可以简化处理。

最新教程 更多>
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-18
  • WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 和内存屏障在访问共享变量的多线程环境中,强制同步至关重要以防止出现意外结果。 Go 中的一种此类机制是“sync.WaitGroup”包,它有助于管理并发运行的 goroutine。当前的问题围绕“WaitGroup.Wait()”和内存屏障之间的关系展开具体代码片...
    编程 发布于2024-11-18
  • 在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    将浮点数精确转换为具有指定十进制精度的字符串在 C 中,将浮点数转换为具有特定精度的字符串,并且小数位需要仔细考虑。本指南探讨了两种常见的解决方案:stringstream 和 C 17 中的 to_chars 函数。使用 StringstreamStringstream 是用于在 C 中操作字符串...
    编程 发布于2024-11-18
  • \“需要帮助修改默认日历选择器的 UI\”
    \“需要帮助修改默认日历选择器的 UI\”
    嗨,团队,我在 AG 网格单元中使用日历,但我无法修改此日历的 UI,也无法检查它。我想更改日历的 UI。 请参阅链接以获取更多说明 https://www.ag-grid.com/examples/provided-cell-editors-date/date-editor/modules/typ...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • 为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    MySQL 文件写入错误(Errcode 28):诊断和解决遇到错误“Errorwriting file '/tmp/MY1fnqpm' (Errcode: 28)” 在 MySQL 查询中,根本原因通常在于可用磁盘空间不足。要确认这一点,请使用 perror 命令:$ perror...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    使用 Sequelize CLI 从 Sequelize 模型自动生成迁移人们可能拥有预先存在的 Sequelize 模型,但希望使用迁移而不是数据库同步。 Sequelize CLI 提供了一篇文章中概述的解决方案,其中指出,“当利用 CLI 进行模型生成时,您将自动获取必要的迁移脚本。”要实现此...
    编程 发布于2024-11-18
  • 为什么Selenium 2.53.0在使用Firefox 47时会遇到连接错误?
    为什么Selenium 2.53.0在使用Firefox 47时会遇到连接错误?
    Selenium 2.53 与 Firefox 47 不兼容使用 Selenium WebDriver 2.53.0 时,遇到错误:org.openqa.selenium.firefox.NotConnectedException: Unable to connect to host 127.0.0...
    编程 发布于2024-11-18
  • 如何构建您的第一个 Web 应用程序:将想法变为现实的初学者指南
    如何构建您的第一个 Web 应用程序:将想法变为现实的初学者指南
    您对网络应用程序有一个想法,但您不确定如何或从哪里开始?构建 Web 应用程序听起来令人畏惧,特别是如果这是您第一次。然而,一步一步地,任何人都可以将他们的想法变成现实,只关注非常重要的组成部分。您将获得可操作的提示和资源,以及有关如何构建您的第一个 Web 应用程序的清晰路线图。 第 1 步:了...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-18
  • 如何仅检索 LEFT JOIN 中的第一行?
    如何仅检索 LEFT JOIN 中的第一行?
    仅检索 LEFT JOIN 中的第一行在 SQL 中,执行 LEFT JOIN 操作可能会导致右表中出现多行与左表中的一行相匹配。在某些情况下,希望为左表中的每一行仅检索右表中的第一行。考虑以下简化的数据结构:**Feeds** id | title | content --------------...
    编程 发布于2024-11-18
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3