MySQL索引失效:为什么shop_id索引在特定查询条件下失效?

mysql索引失效:为什么shop_id索引在特定查询条件下失效?

MySQL索引失效场景分析

本文分析一个MySQL索引失效的案例,并探讨其原因。

数据库表结构如下:

CREATE TABLE `ns_delivery_shop` (  `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,  `goods_id` INT(10) NOT NULL COMMENT '商品id',  `sku_id` INT(10) NOT NULL COMMENT '商品sku',  `shop_id` INT(10) NOT NULL COMMENT '代理商id',  `stock` INT(10) NOT NULL COMMENT '库存',  `sales` INT(10) NOT NULL COMMENT '销量',  `create_time` INT(10) NOT NULL COMMENT '时间',  PRIMARY KEY (`id`),  KEY `idx_shop_id` (`shop_id`) USING BTREE) ENGINE=INNODB AUTO_INCREMENT=7 DEFAULT CHARSET=UTF8 COMMENT='代理商打货表';

部分示例数据:

INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (1, 86, 99, 1, 10, 5, 1613960196);INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (2, 86, 100, 1, 15, 10, 1613960196);INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (3, 86, 101, 1, 25, 10, 1613960196);INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (4, 101, 119, 9, 30, 5, 1613960196);INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (5, 101, 119, 11, 30, 5, 1613960196);INSERT INTO `ns_delivery_shop`(`id`, `goods_id`, `sku_id`, `shop_id`, `stock`, `sales`, `create_time`) VALUES (6, 101, 119, 12, 30, 5, 1613960196);

执行以下查询语句时,索引idx_shop_id失效:

EXPLAIN SELECT stock FROM `ns_delivery_shop` WHERE shop_id = 1;

失效原因分析:

索引失效的原因是当满足shop_id = 1条件的数据量占总数据量的比例超过MySQL优化器预设的阈值时,MySQL会认为全表扫描效率更高,从而选择忽略索引。 这与数据量大小和数据分布有关。 在小数据量的情况下,这个阈值的影响可能不明显。 但随着数据量的增加,如果符合条件的数据占比过高,索引就可能被优化器放弃。

以上就是MySQL索引失效:为什么shop_id索引在特定查询条件下失效?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1252877.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 00:27:23
下一篇 2025年12月9日 20:27:30

相关推荐

  • MySQL索引失效:当数据占比超过一定阈值后,索引为什么失效?

    MySQL索引失效:数据占比过高引发的性能问题 MySQL索引是提升数据库查询效率的关键,但某些情况下索引会失效,导致查询性能急剧下降。本文将分析一个常见的索引失效场景:高数据占比导致索引失效。 问题:索引失效的特定条件 假设一个数据表包含shop_id索引。当查询shop_id = 1时,索引起作…

    2025年12月10日
    000
  • Blade模板继承失效:为什么我的子模板内容没有显示?

    Blade模板继承问题排查 在使用Laravel Blade模板继承时,子模板内容无法显示是一个常见问题。 本文将针对子模板内容缺失,且父模板未定义@section的情况进行分析和解决。 您遇到的问题是:尽管继承路径正确,但父模板中缺少用于内容填充的@section块定义,导致子模板内容无法在父模板…

    2025年12月10日
    000
  • 阿里云服务器SSH连接失败但已有连接正常,是什么原因?

    阿里云服务器SSH连接中断,但现有连接保持活跃 问题现象: 阿里云服务器出现间歇性无法SSH连接的情况。80端口网站也无法访问,但已建立的SSH连接却能正常工作。服务器ping通,CPU、内存、带宽资源正常,打开文件数量也无异常。 可能原因: 服务器并发连接数达到上限,导致新的SSH连接无法建立。 …

    2025年12月10日
    000
  • AppServer下phpMyAdmin无法登录,是什么原因导致的以及如何解决?

    AppServer环境下phpMyAdmin无法登录的排查与解决 在AppServer环境中安装phpMyAdmin后,即使用户名密码正确,也可能出现反复跳转回登录页面的情况。 这通常是由于AppServer的会话配置问题导致的。 问题根源: AppServer默认使用文件系统存储会话信息,这容易造…

    2025年12月10日
    000
  • Go语言如何通过API重启Docker容器?

    Go语言与Docker API集成:实现代码变更后自动重启容器 在Swoole开发中,代码更新后快速重启Docker容器至关重要。本文介绍如何使用Go语言和Docker API实现此功能。 解决方案: Go语言的go-dockerclient库提供了与Docker API交互的便捷方式。 立即学习“…

    2025年12月10日
    000
  • ThinkPHP5 Windows服务器缓存写入失败怎么办?

    ThinkPHP5在Windows服务器缓存写入失败的解决方法 许多用户在Windows服务器环境下使用ThinkPHP5框架时,常常遇到缓存写入失败的问题,报错信息通常显示为file_put_contents(C:phpStudyPHPTutorialWWWappruntimecache4f819…

    2025年12月10日
    000
  • PHP MySQL分页查询:如何高效实现精准分页并获取总记录数?

    PHP MySQL 高效分页查询技巧 本文介绍在PHP中优化MySQL分页查询的方法,确保高效性能和准确结果。 正确的SQL语句 不正确的SQL语句会导致分页结果错误。 以下展示了正确的分页查询方式: 立即学习“PHP免费学习笔记(深入)”; SELECT * FROM student LIMIT …

    2025年12月10日
    000
  • Fiddler 只抓到 Connect 请求且 App 无法联网是什么原因?

    为什么 fiddler 抓到的都是 connect 请求,且 app 无法连接网络? 问题描述: 如图所示,使用 Fiddler 抓取 App 网络请求时,抓到的全是 Connect 请求,而且 App 无法连接网络,而浏览器可以正常联网。 解决方法: 检查手机是否安装了 Fiddler 的 CA …

    好文分享 2025年12月10日
    000
  • PHP7版本更新对session处理有什么影响

    PHP7 对 Session 的优化带来了性能提升和安全性增强:性能优化:引擎优化减少了 Session 处理开销,提升了 Session 读写速度。安全性增强:对 Session ID 生成机制的调整增强了安全性,但仍需采取其他安全措施。潜在注意事项:迁移到 PHP7 可能存在兼容性问题,需要检查…

    2025年12月10日
    000
  • PHP 8如何进行安全部署

    如何在安全地部署 PHP 8 应用:代码层面:编写安全的代码,防止注入和跨站脚本攻击。服务器配置:禁用不必要的扩展,配置权限,使用 HTTPS,启用 HTTP 安全头。数据库安全:使用强密码,设置访问控制,进行备份,监控活动。定期安全审计:使用扫描工具,发现并修复漏洞。高级技巧:使用 OPcache…

    2025年12月10日
    000
  • PHP 8如何响应安全事件

    PHP 8 的安全事件响应需要遵循系统化的流程,包括:隔离受影响系统、收集证据、分析攻击、修复漏洞、恢复系统和持续监控。为了增强安全,应了解 PHP 安全函数、参数化查询、文件上传验证、会话管理,并考虑入侵检测系统。常见的错误包括依赖过时的库、忽略安全警告和不进行安全测试,应遵循最佳实践以实现安全和…

    2025年12月10日
    000
  • PHP 8如何建立安全意识

    PHP 8 的安全意识构建了一个多层次的防御体系,涵盖输入验证、数据过滤、输出编码、安全函数应用以及服务器配置,以应对安全风险,包括 SQL 注入、XSS、CSRF 和文件包含漏洞。通过采用严格的验证、过滤和编码措施,加上安全函数和适当的服务器配置,开发人员可以主动构建安全的应用程序,而非被动地修补…

    2025年12月10日
    000
  • 了解Laravel应用中的坚实原则

    Laravel应用中的SOLID原则:构建更健壮的应用 干净、易于维护的软件设计,其基石在于SOLID原则。这五个原则——单一职责原则(SRP)、开放封闭原则(OCP)、Liskov替换原则(LSP)、接口隔离原则(ISP)和依赖反转原则(DIP)——帮助开发者构建可扩展、可测试且易于维护的系统。本…

    2025年12月10日
    000
  • 在测试中使用Laravel中的PHP后备枚举

    PHP 枚举概述 PHP 8.1 引入了枚举,提供了一种定义命名值集合的结构化方式。Laravel 与枚举无缝集成,允许在模型、验证规则和查询条件中使用它们。然而,在测试中,一些细微之处可能会导致意外的失败。 示例:订单项目状态枚举 这是一个订单项目状态的后备枚举示例: namespace AppS…

    2025年12月10日
    000
  • 优化PHP应用程序:为什么单独阅读和写入模型很重要

    模型是与数据存储交互的理想工具。它们定义数据的结构,确保与数据存储(通常是数据库)兼容。模型不仅验证输入数据,辅助数据写入,还能用于数据检索。然而,除了简单的CRUD应用之外,将同一个模型用于读写通常并非最佳实践。让我们深入探讨原因。 创建模型 让我们以一个简单的用户模型和存储库接口为例,这里无需详…

    2025年12月10日
    000
  • PHP本地开发工具5

    > phpstudy Web:Web开发的综合工具 PhPstudy Web是一种非常流行且用户友好的软件,旨在帮助开发人员有效地设置和管理Web服务器和PHP环境。 PhpStudy Web以其简单性和多功能性而闻名,在网络开发社区中广泛使用,尤其是用于本地开发和测试。 什么是phpstud…

    2025年12月10日
    000
  • 为什么我讨厌WordPress,但是为什么它仍然很棒和必要

    WordPress占据着超过40%的网站市场份额,是目前最流行的内容管理系统(CMS)。然而,在软件工程师群体中,特别是后端开发和可扩展Web应用领域的工程师,WordPress因其低效、臃肿和令人沮丧的特性而臭名昭著。 我个人非常不喜欢WordPress。我花费了大量时间处理其混乱的代码库、解决插…

    2025年12月10日
    000
  • PHP 8如何进行数据库连接安全

    要安全地连接 PHP 8 数据库,需要保护凭据并防止 SQL 注入:使用预处理语句分离 SQL 查询和数据,以避免 SQL 注入。使用密码哈希存储密码,防止泄露。遵循最小权限原则,限制用户的数据库访问权限。使用 HTTPS 加密数据传输。验证用户输入,防止恶意数据进入。 PHP 8 数据库连接安全:…

    2025年12月10日
    000
  • Windows RDP托管:远程开发工作区的完整指南

    作为当今数字时代的开发人员,拥有一个可靠且强大的远程工作空间不仅是一种奢侈品,而且是必不可少的。 Windows远程桌面协议(RDP)托管在开发人员中越来越受欢迎,这是有充分理由的。在本指南中,我将分享我在Windows RDP托管方面的经验,以及为什么它可能是您想要的解决方案。 **为什么每个开发…

    好文分享 2025年12月10日
    000
  • 设计一个数字容器系统

    设计一个高效的数字容器系统,支持以下操作: 插入/替换: 将指定索引处的值替换为新值。如果索引不存在,则插入新值。查找最小索引: 返回给定数字在容器中出现的最小索引。如果数字不存在,则返回 -1。 挑战难度: 中等 相关主题: 哈希表,设计模式,最小堆(优先队列) 示例: [“NumberConta…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信