mysql delete from 条件 in 子查询 很慢优化

DELETE 
FROM
	t_workflow_info 
WHERE
	TaskNo IN (
	SELECT
		a.form_no 
	FROM
		t_electric_maint_form_accept_v2 a
		LEFT JOIN t_electric_maint_task_v2 a1 ON a.maint_task_id = a1.id 
	WHERE
		a1.form_no IN ('CQ-YJRW-ZX2304250002',
'CQ-YJRW-ZX2304250001') 
	);

这种方式 删除条件为 in 子查询会很慢。

DEPENDENT SUBQUERY: 子查询中的SELECT, 取决于外面的查询。

换句话说,就是子查询执行方式依赖于外层的查询结果。

什么意思呢?它以为着两步走:第一步:【先执行外部SQL查询】MySQL根据”DELETE FROM t_workflow_info  WHERE” 得到一个大结果集t1,其数据量就是全表所有行了,假设是85万行。

第二步:【后执行内部SQL子查询】第一步的大结果集t1中的每一条记录,都将与子查询SQL组成新的查询语句:SELECT
        a.form_no 
    FROM
        t_electric_maint_form_accept_v2 a
        LEFT JOIN t_electric_maint_task_v2 a1 ON a.maint_task_id = a1.id 
    WHERE
        a1.form_no IN ('CQ-YJRW-ZX2304250002',
'CQ-YJRW-ZX2304250001')  and a.form_no = %TaskNo%。等于说,子查询要执行85万次……即使这两部查询都用到了索引,也是巨慢的。

优化方式:

DELETE info 
FROM
	t_workflow_info AS info
	LEFT JOIN t_electric_maint_form_accept_v2 a ON info.TaskNo = a.form_no
	LEFT JOIN t_electric_maint_task_v2 a1 ON a.maint_task_id = a1.id 
WHERE
	a1.form_no IN ( 'CQ-YJRW-ZX2304250002', 'CQ-YJRW-ZX2304250001' );

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值