加了索引,mysql查询就一定会用吗?

本文探讨了mysql中加了索引却不被使用的情况,包括查询条件涉及函数、隐式类型转换、特殊修饰符如%和OR、以及索引优化器的选择。索引优化器根据区分度估算最佳执行方案,基数小可能导致不走索引。通过force index可强制使用特定索引。了解这些原理有助于避免查询性能问题。
摘要由CSDN通过智能技术生成

 

小白白跑去鹅厂面试,面试官提出了一个很实际的问题: mysql增加索引,那些情况会失效呢?谈一下实际工作中遇到的情况。我们的小白白又抛出了白氏秘籍:用不用索引,找DBA小姐姐!啊?这是你面试哈,还是DBA小姐姐面试呀。(更多信息,请关注微信公众号: 白白家族)


一 概述

日常处理mysql问题中,往往通过增加索引来提高查询速度,但在有些情况下,执行过程中并没有按照我们的预期结果执行,也就是说,即使字段加了索引,但现实也没有使用到,到底是什么地方出了差错,以下我们将一探究竟。


二 实验表结构声明:

我们将对以下表结构进行实际案例分析

CREATETABLE `student` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `age` int(11) DEFAULT 0,  `name` varchar(16) DEFAULT "",  key idx_age (`age`),  key idx_name (`name`),
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值