mysql 子查询SQL性能优化

在这里插入图片描述
xx(1111111) 13:15:54
执行了好长直接了
xx(1111111) 13:15:56
时间了
在这里插入图片描述

郭xx(39444) 13:24:32
这个 可以 改写成 left join
郭xx(39444) 13:24:51
驱动表 88w 行,你可以 试试 改写一下
郭xx(39444) 13:26:02
来来,把sql 发上来,我给你改写一下,你在查试试
xx(1111111)13:26:32
SELECT COUNT(*),app_name
FROM t_statistics_use_app
WHERE msisdn_full IN
(SELECT DISTINCT msisdn
FROM t_client_useraction_log where reg_time >=‘2019-03-10 00:00:00’
AND business_type = ‘22’
)GROUP BY app_name

郭xx(39444) 13:41:54
select count(*) ,t1.app_name from t_statistics_use_app t1 left join (select distinct msisdn from t_client_useraction_log where reg_time >=‘2019-03-10 00:00:00’ AND business_type = ‘22’) t2 on t1.msisdn_full=t2.msisdn where t2.msisdn is not null group by t1.app_name

xx(1111111)13:42:58
老郭 你这个也是80W啊
在这里插入图片描述
xx(1111111)13:44:40
卧槽
xx(1111111)13:44:40

在这里插入图片描述
总结:
使用left join 优化 子查询的案例不光在mysql 中好使,在oracle中也很有效,但也不能一概而论,通常in的内容较大可以使用left join进行优化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值