以前学习这一块的时候,是说:假设建立了联合索引a+b,那么查询语句也一定要是这个顺序才能应用该索引。

那么实际是怎样呢,经过mysql这么多次版本升级,相信mysql已经给我们做了某些优化。

下面是我的实测结果:(5.7版本)

step1:反顺序也是可以应用索引的。

step2:正常顺序更加没问题

step3:在有单列索引情况下,竟然优先使用了联合索引

step4:将idx_name_del中的索引顺序换了下,把name换前面。

step5:将idx_pid_del中的索引顺序换了下,把pid换前面。这下优化器显示:使用单列索引。

总结:

结论1:在有联合索引时,顺序已不再要紧,mysql内部已经做了优化,只要是联合索引的那几个条件与where子句中的条件匹配,都能应用对应的联合索引。

结论2:在有联合索引(a+b)和单列索引a同时存在时,通过a条件的查询会优先使用联合索引。

结论3:在有联合索引(b+a)和单列索引a同时存在时,通过a条件的查询会使用单列索引,联合查询不会出现在possible keys中。

最新文章

  1. CLR线程概览(一)
  2. java中Date与String的相互转化
  3. GNUPLOT 画多组柱状图 以及 折线图 以及各种问题的解决方案
  4. 【摘自网络】陈奕迅&&杨千嬅
  5. SyncServer obj
  6. hdu 4712 Hamming Distance(随机数法)
  7. wait函数返回值总结
  8. 切换加上延迟加载js代码
  9. bzoj1028
  10. linux 部分命令简单使用介绍-ssh、scp、less、tail、find、grep(持续添加)
  11. Python 函数的使用 外加引入文件
  12. CentOS6.5 安装snort
  13. css3 结构性伪类选择器
  14. isFile() exists() isDirectory()的区别
  15. PHP 包含
  16. B/S架构
  17. 前端之js
  18. xshell 会话管理器快捷键
  19. python---ORM之SQLAlchemy(4)relationship多对多练习
  20. 简单记录下3PC

热门文章

  1. VS 2017 开发安卓环境搭建 问题总结
  2. Python进程-实现
  3. Jdk1.7+eclipse搭建Java开发环境
  4. linux服务器中毒可疑进程sfewfesfs CPU80%
  5. 设计模式 --> (12)装饰模式
  6. java数组排序,并将数组内的数据求和
  7. dubbo服务简单搭建
  8. 动态规划(Dynamic programming) 走楼梯
  9. LeetCode-4. 两个排序数组的中位数(详解)
  10. JavaScript简史