索引提示 mysql_MySQL中的索引提示Index Hint

MySQL数据库支持索引提示(INDEX HINT)显式的高速优化器使用了哪个索引。以下是可能需要用到INDEX HINT的情况

a)MySQL数据库的优化器错误的选择了某个索引,导致SQL运行很慢。这个在最新版的数据库版本中非常少见。优化器在绝大部分情况下工作的非常有效和正确。

b)某些SQL语句可以选择的索引非常多,这时优化器选择执行计划时间的开销可能会大于SQL语句本身例如优化器分析Range查询本身就是比较耗时的操作。这时DBA或开发人员分析最优的索引选择,通过index hint来强制使优化器不进行各个路径的成本分析直接选择指定的索引来完成查询

MySQL数据库的Index Hint语法

28ef20c7c0302cd03387e23188a8c2b6.png

看个表结构

CREATE TABLEt(

aINT,

bINT,KEY(a),KEY(b)

)ENGINE=INNODB;INSERT INTO t SELECT 1,1;INSERT INTO t SELECT 1,2;INSERT INTO t SELECT 2,3;INSERT INTO t SELECT 2,4;INSERT INTO t SELECT 1,2;

查看执行计划

32c0164ba8af829df9d4274e0123e41b.png

如图SQL语句可以使用a,b索引,实际使用的索引为b,a完成整个查询,列Extra提示Using intersect(b,a)表示根据两个索引得到的结果进行求交的数学运算,最后得到结果

如果我们使用USE INDEX 的索引来使用a这个索引呢

EXPLAIN SELECT * FROM t USE INDEX(a) WHERE a=1 AND b=2;

22f326b25b4862e1220aa2ff69b2b9bf.png

可以发现,优化器使用了a的索引,但use index只是告诉优化器可以选择该索引,实际上优化器还是会根据自己的判断进行选择,最可靠的做法是FORCE INDEX

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值