mysql复合索引
ringa_lee
ringa_lee 2017-04-17 12:58:00
[MySQL讨论组]

是这样的,表里边有2个字段DistriType varchar(20)和DistriButTime int(11),我建了一个联合索引KEY DistriType (DistriType,DistriButTime),执行了一个查询计划SELECT * FROM zt_customerinfo WHERE DistriButTime<1417327703 AND DistriType="xxx"看到搜索结果应用到了联合索引且扫了364行,如果将联合索引的顺序换一下KEY DistriType (DistriButTime,DistriType) 再执行explain看到扫表2800多行,相当于只应用了单索引DistriButTime,请问这是什么原因~

ringa_lee
ringa_lee

ringa_lee

全部回复(3)
黄舟

对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。
例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3种组合进行查找,但不支持 b,c进行查找。

由于你的where 条件中有一个使用的是范围查找,所以不能你的联合索引的两个字段不能都用上。根据上面的规则,在第一种情况下,使用的索引为 DistriType, 第二种情况下使用的是 DistriButTime

怪我咯

范围查找为什么不能两个都用上?

大家讲道理

第二种情况,对于复合索引,如果第一个字段使用了范围查询,那么后面的字段将不再使用索引

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号