mysql联合索引经典实例

某表有二个索引,一个是a,b,c三字段联合索引,一个是c字段单独索引,请问下列sql语句,能否使用上索引?

  1. where a=1 and b=2 and c=3 (使用联合索引)

  2. where a = 1 and b>2 and c=3 (使用c索引)

  3. where a > 1 and b=2 and c=3 (使用c索引)

  4. where a > 1 and b=2 and c>3 (不使用索引)

  5. where a>1 and b!=2 (不使用索引)

  6. where a!=1 and b>1 (不使用索引)

  7. where b = 1 and a = 2 (使用联合索引)

  8. where b = 1 (不使用索引)

  9. where a = 1 (使用联合索引、若a字段存在单独索引,此处仍优先使用联合索引)

  10. where c = 1 order by b (使用c索引)

  11. where c = 1 order by a (使用c索引)

  12. where b = 1 order by a (不使用索引)

  13. where b = 1 order by c (不使用索引)

  14. where b = 1 group by c (使用c索引)

备注:

  1. 范围查询用不上索引。
  2. 联合索引中,若存在范围查询时,优先使用其他准确查找字段中的单独索引。
  3. 联合索引中,若a,b,c、 a,b、 a,c、 a 组合(即含有a字段的组合)均为精确查找,则使用联合索引。(与where语句中三个字段出现的顺序无关)
  4. 联合索引中,若字段组合中不含有a字段且b、c字段均无单独字段索引,则不使用索引。
相关推荐
小bo波10 小时前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
nanxun8861 天前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103512 天前
Day01 | Java 基础(Java SE)
java
行者全栈架构师2 天前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师2 天前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_02 天前
mac(m5)平台编译openjdk
java
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
唐青枫3 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二3 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程