MySQL——强制索引优化背后的学习

MySQL——强制索引优化背后的学习

1. 背景

某天,遇到一个神奇的SQL语句。神奇点如下:

  1. 同一条SQL语句,当参数不同时,查询速度相差很大;
  2. 在对该条SQL语句进行优化时,使用强制走某个索引后,查询速度从5s到0.05ms;

针对以上问题,记录下整个优化过程及背后的原理。

2. 慢SQL语句

以下为脱敏后的SQL语句:

SELECT
	a2.fieldmenu_id 
FROM
	a2
	INNER JOIN m2 ON a2.fieldmenu_id = m2.id 
	AND m2.client_id = '123' 
	AND m2.state = 1 
	AND m2.unable = 1 
	AND m2.type = 0
	INNER JOIN b2 ON a2.id = b2.fieldresources_id 
	AND b2.state = 1 
	AND b2.unable = 1
	INNER JOIN c2 ON b2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值