减少大型查询的执行时间
Reduce the execution time of large query
我的查询需要 30 分钟以上的时间来处理此查询。它确实适用于非常大的数据集,但是我可能会遗漏一些可以减少执行时间的基本内容。
查询适用于许多减速器阶段,每个阶段使用 1000 多个减速器。在 Tez 引擎上运行。
我尝试启用 CBO 但没有成功,还尝试将 reducers 限制为 500
但执行时间仍然很长。
select itt.tr_date, sum (bkt_sum_pc) as pts
from itops_trxn itt,
( select acttrxnID, max(act_cmp_id) as act_cmp_id
from itops_trxn_act a, ll_act_act_trxn b where a.act_trxn_ID = b.ACOUNTtrxnID group by acttrxnID
) A,
(select cmp_id, max (cmp_name) as name
from itops_offer group by cmp_id
) c
where itt.acttrxnID = A.acttrxnID and act_cmp_id = c.cmp_id
and itt.type = 'ajstmnt'
and itt.event_header_event_name NOT IN ('composite.sys.act.merge', 'pos.sys.identity', 'composite.sys.act.pcmerge')
and itt.event_atomic_operation_type = 'CT'
and itt.tr_date >='2018-10-31'
group by itt.tr_date, channel, location_storeparentid, meta_trxnreason, act_cmp_id,name;
显式重写连接并移动这些条件
where itt.acttrxnID = A.acttrxnID and act_cmp_id = c.cmp_id
加入 ON 子句:
select itt.tr_date, sum (bkt_sum_pc) as pts
from itops_trxn itt
INNER JOIN
( select acttrxnID, max(act_cmp_id) as act_cmp_id
from itops_trxn_act a, ll_act_act_trxn b where a.act_trxn_ID = b.ACOUNTtrxnID group by acttrxnID
) A ON itt.acttrxnID = A.acttrxnID
INNER JOIN
(select cmp_id, max (cmp_name) as name
from itops_offer group by cmp_id
) c ON A.act_cmp_id = c.cmp_id
where itt.type = 'ajstmnt'
and itt.event_header_event_name NOT IN ('composite.sys.act.merge', 'pos.sys.identity', 'composite.sys.act.pcmerge')
and itt.event_atomic_operation_type = 'CT'
and itt.tr_date >='2018-10-31'
group by itt.tr_date, channel, location_storeparentid, meta_trxnreason, act_cmp_id,name;
我的查询需要 30 分钟以上的时间来处理此查询。它确实适用于非常大的数据集,但是我可能会遗漏一些可以减少执行时间的基本内容。
查询适用于许多减速器阶段,每个阶段使用 1000 多个减速器。在 Tez 引擎上运行。
我尝试启用 CBO 但没有成功,还尝试将 reducers 限制为 500 但执行时间仍然很长。
select itt.tr_date, sum (bkt_sum_pc) as pts
from itops_trxn itt,
( select acttrxnID, max(act_cmp_id) as act_cmp_id
from itops_trxn_act a, ll_act_act_trxn b where a.act_trxn_ID = b.ACOUNTtrxnID group by acttrxnID
) A,
(select cmp_id, max (cmp_name) as name
from itops_offer group by cmp_id
) c
where itt.acttrxnID = A.acttrxnID and act_cmp_id = c.cmp_id
and itt.type = 'ajstmnt'
and itt.event_header_event_name NOT IN ('composite.sys.act.merge', 'pos.sys.identity', 'composite.sys.act.pcmerge')
and itt.event_atomic_operation_type = 'CT'
and itt.tr_date >='2018-10-31'
group by itt.tr_date, channel, location_storeparentid, meta_trxnreason, act_cmp_id,name;
显式重写连接并移动这些条件
where itt.acttrxnID = A.acttrxnID and act_cmp_id = c.cmp_id
加入 ON 子句:
select itt.tr_date, sum (bkt_sum_pc) as pts
from itops_trxn itt
INNER JOIN
( select acttrxnID, max(act_cmp_id) as act_cmp_id
from itops_trxn_act a, ll_act_act_trxn b where a.act_trxn_ID = b.ACOUNTtrxnID group by acttrxnID
) A ON itt.acttrxnID = A.acttrxnID
INNER JOIN
(select cmp_id, max (cmp_name) as name
from itops_offer group by cmp_id
) c ON A.act_cmp_id = c.cmp_id
where itt.type = 'ajstmnt'
and itt.event_header_event_name NOT IN ('composite.sys.act.merge', 'pos.sys.identity', 'composite.sys.act.pcmerge')
and itt.event_atomic_operation_type = 'CT'
and itt.tr_date >='2018-10-31'
group by itt.tr_date, channel, location_storeparentid, meta_trxnreason, act_cmp_id,name;