Запрос с несколькими подзапросами слишком медленный
Есть ли способ оптимизировать запрос ниже? Я считаю, что он показывает результат медленно, почти 15 минут, для получения 3500 записей. Я подозреваю, что это из-за подзапросов.
SELECT
MSTUDYPROCESS.I_PROCESS_PL,
MPROCESS.N_PROCESS_PL C_PART_CODE,
MPROCESS.I_LOAD_TYP,
MPROCESS.I_ASME_GRP,
(
SELECT
MASMEGRP.N_ASME_GRP
FROM
MASMEGRP
WHERE
MASMEGRP.I_ASME_GRP = MPROCESS.I_ASME_GRP
) N_ASME_GRP,
MSTUDYPROCESS.Q_COMMON_PARTS_PER_HIT,
MSTUDYPROCESS.I_AUTOM_TYP,
MSTUDYPROCESS.I_STMPG_PART_TYP,
MSTUDYPROCESS.I_BLNK_TYP,
MSTUDYPROCESS.I_ASSY_TYP,
MSTUDYPROCESS.Q_PARTS_PER_HIT,
MSTUDYPROCESS.Q_NMBR_OF_DIES,
MSTUDYPROCESS.Q_STN_REQD,
MSTUDYPROCESS.L_TOGGLE,
MSTUDYPROCESS.Q_SHUT_HGT,
MSTUDYPROCESS.X_COMNT,
MSTUDYPROCESS.N_PART_PL,
MSTUDYPROCESS.N_PART_PL_ADDNL,
CASE
(
SELECT
COUNT(*)
FROM
MPROCESSDEPEND
WHERE
MPROCESSDEPEND.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
) WHEN 0 THEN 0 ELSE 1 END IS_MASSYDETAIL,
CASE
(
SELECT
COUNT(*)
FROM
MOFFLOAD
WHERE
MOFFLOAD.I_STDY = MSTUDYPROCESS.I_STDY
AND MOFFLOAD.N_PROCESS_PL = MPROCESS.N_PROCESS_PL
) WHEN 0 THEN 0 ELSE 1 END IS_MOFFLOAD,
(
SELECT
COUNT(DISTINCT I_MODEL_YR)
FROM
MLOADFORECAST
WHERE
MLOADFORECAST.I_STDY = MSTUDYPROCESS.I_STDY
AND MLOADFORECAST.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
) NUM_YEARS,
EPL.Get_Line_BX(MSTUDYPROCESS.I_STDY, MSTUDYPROCESS.I_PROCESS_PL) BLANK_LINE,
MSTUDYPROCESS.I_UPD_TID,
MSTUDYPROCESS.D_UPD_LAST
FROM
MSTUDYPROCESS,
MPROCESS
WHERE
MSTUDYPROCESS.I_STDY = IN_I_STDY
AND MPROCESS.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
ORDER BY
MPROCESS.N_PROCESS_PL;
1 ответ
Попробуйте без вашей хранимой процедуры, как это
SELECT
MSTUDYPROCESS.I_PROCESS_PL,
Process_1.N_PROCESS_PL C_PART_CODE,
Process_1.I_LOAD_TYP,
Process_1.I_ASME_GRP,
grp.N_ASME_GRP,
MSTUDYPROCESS.Q_COMMON_PARTS_PER_HIT,
MSTUDYPROCESS.I_AUTOM_TYP,
MSTUDYPROCESS.I_STMPG_PART_TYP,
MSTUDYPROCESS.I_BLNK_TYP,
MSTUDYPROCESS.I_ASSY_TYP,
MSTUDYPROCESS.Q_PARTS_PER_HIT,
MSTUDYPROCESS.Q_NMBR_OF_DIES,
MSTUDYPROCESS.Q_STN_REQD,
MSTUDYPROCESS.L_TOGGLE,
MSTUDYPROCESS.Q_SHUT_HGT,
MSTUDYPROCESS.X_COMNT,
MSTUDYPROCESS.N_PART_PL,
MSTUDYPROCESS.N_PART_PL_ADDNL,
CASE DEPEND.NBDEPEND WHEN 0 THEN 0 ELSE 1 END IS_MASSYDETAIL,
CASE OFFLOAD.NBMOFFLOAD WHEN 0 THEN 0 ELSE 1 END IS_MOFFLOAD,
LOADFORECAST.NBMLOADFORECAST NUM_YEARS,
Proc2.I_PRES_LINE BLANK_LINE,
MSTUDYPROCESS.I_UPD_TID,
MSTUDYPROCESS.D_UPD_LAST
FROM
MSTUDYPROCESS inner join MPROCESS Process_1 on Process_1.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
left outer join lateral
(
SELECT MASMEGRP.N_ASME_GRP FROM MASMEGRP
WHERE MASMEGRP.I_ASME_GRP = Process_1.I_ASME_GRP
fetch first rows only
) grp on 1=1
inner join lateral
(
SELECT COUNT(*) NBDEPEND FROM MPROCESSDEPEND
WHERE MPROCESSDEPEND.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
) DEPEND on 1=1
inner join lateral
(
SELECT COUNT(*) NBMOFFLOAD FROM MOFFLOAD
WHERE MOFFLOAD.I_STDY = MSTUDYPROCESS.I_STDY
AND MOFFLOAD.N_PROCESS_PL = Process_1.N_PROCESS_PL
) OFFLOAD on 1=1
inner join lateral
(
SELECT COUNT(DISTINCT I_MODEL_YR) NBMLOADFORECAST FROM MLOADFORECAST
WHERE MLOADFORECAST.I_STDY = MSTUDYPROCESS.I_STDY
AND MLOADFORECAST.I_PROCESS_PL = MSTUDYPROCESS.I_PROCESS_PL
) LOADFORECAST on 1=1
left outer join lateral
(
SELECT MLOADFORECAST.I_PRES_LINE
FROM MPROCESS Process_2 inner join MLOADFORECAST on MLOADFORECAST.I_PROCESS_PL= Process_2.I_PROCESS_PL
WHERE Process_2.N_PROCESS_PL= Process_1.N_PROCESS_PL
and Process_2.I_LOAD_TYP = CASE Process_1.I_LOAD_TYP WHEN 'B' THEN 'X' WHEN 'X' THEN 'B' END
AND MLOADFORECAST.I_STDY= MSTUDYPROCESS.I_STDY
ORDER BY MLOADFORECAST.I_MODEL_YR, MLOADFORECAST.I_PRES_LINE
FETCH FIRST ROW ONLY
) Proc2 on 1=1
WHERE MSTUDYPROCESS.I_STDY = IN_I_STDY
ORDER BY Process_1.N_PROCESS_PL;