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进行优化