Oracle SQL Query Optimization (левые объединения, индексы) - PullRequest
0 голосов
/ 05 апреля 2019

Следующий запрос застревает при добавлении таблицы в набор левого соединения. Запрос выполняется гладко, если последнее соединение исключено. но застревает, если включено последнее соединение. Я также попробовал подсказки оптимизатора ALL_ROWS, FIRST_ROWS. От cps_taskhis для «20190404» ожидается около 5500 строк.

Примечания:

  • Таблица cpsmgt.cps_orderhis.orderid является индексированным столбцом. {скриншот 1}.

  • Таблица cpsmgt.cps_taskhis.orderid также является индексированным столбцом, который присоединяется к cpsmgt.cps_orderhis.orderid в последнем левом соединении. {снимок экрана 2}

Снимок экрана 1: enter image description here

Снимок экрана 2: enter image description here SQL-запрос

SELECT /*FIRST_ROWS*/
    t.taskid task_no,
    t.orderid order_id,
    DECODE(t.priority,50,'Low',100,'Medium',200,'High','Other') task_priority,
    t.taskname task_name,
    TO_CHAR(t.createtime,'HH24') creation_hour,
    t.createtime create_time,
    t.completedtime completed_time,
    ( to_timestamp(t.completedtime,'yyyy-mm-dd hh24:mi:ss') - to_timestamp(t.createtime,'yyyy-mm-dd hh24:mi:ss') ) time_difference,
    op1.user_name initiator_login,
    rd1.name role_assigned_maker,
    op2.user_name checker_login,
    rd2.name role_assigned_checker,
    t.taskstate task_state,
    t.tasktype task_type,
    t.description task_description,
    ord_comment.commenttext,  -- 2048 byte varchar2
    sim.msisdn target_msisdn, 
    o.reason reason_of_task,  -- 2048 byte varchar2
    DECODE(t.bussinesscategory,'0','Business Operation','1','Transaction and Action','2','Financial','3','Manual Task','4','Bulk','5'
,'Configuration','Others:'
    || t.bussinesscategory) businesscategory_of_task
FROM
    cpsmgt.cps_taskhis t --PARTITION ( SYS_P30212 ) t
    LEFT JOIN cpsmgt.cps_operator op1 ON op1.operator_id = t.createid
    LEFT JOIN cpsmgt.cps_operator op2 ON op2.operator_id = t.ownerid
    LEFT JOIN cpsmgt.cps_role_operator ro1 ON op1.operator_id = ro1.operator_id
                                              AND op1.status <> '06'
    LEFT JOIN cpssys.cps_role_def rd1 ON rd1.role_id = ro1.role_id
                                         AND rd1.status = '30'
    LEFT JOIN cpsmgt.cps_role_operator ro2 ON op2.operator_id = ro2.operator_id
                                              AND op2.status <> '06'
    LEFT JOIN cpssys.cps_role_def rd2 ON rd2.role_id = ro2.role_id
                                         AND rd2.status = '30'
    LEFT JOIN cpsmgt.cps_order_comment ord_comment ON t.orderid = ord_comment.orderid
    LEFT JOIN cpsmgt.cps_sim_device sim ON t.on_identity_id = sim.identity_id
    LEFT JOIN cpsmgt.cps_orderhis o ON t.orderid = o.orderid
WHERE
    t.createtime BETWEEN TO_DATE(TO_CHAR(20190404)
    || ' 00:00:00','yyyy-mm-dd hh24:mi:ss') AND TO_DATE(TO_CHAR(20190404)
    || ' 23:59:59','yyyy-mm-dd hh24:mi:ss')
    AND   t.procdefid IN (
        'IC_EditP2PMSISDNWorkflow',
        'IC_ResetCustomerPinWorkflow',
        'TC_TransactionConfirmWorkflow',
        'IC_ChangeCustomerProductWorkflow',
        'IC_EditG2PMSISDNWorkflow',
        'IC_ChangeCustomerIdentityStatusWorkflow',
        'TC_CancelRemittanceWorkflow',
        'IC_ChangeCustomerMSISDNWorkflow',
        'IC_ResetOrgOperatorPINWorkflow',
        'IC_MigrateCustTrustL1Workflow',
        'IC_MigrateCustTrustL2Workflow',
        'IC_ChangeCustomerIdentityKYCWorkflow',
        'IC_UnblockPaymentTransactionWorkflow',
        'IC_ResetOrgOperatorPasswordWorkflow'
    )
    AND   rd1.name IN (
        'Complaints (Maker)',
        'MFS 1344 Help Line',
        'MFS 4444 Helpline',
        'Operator user(back end user) maker',
        'Complaints Checker',
        'Operator user(back end user) completer'
    )
    AND   rd2.name IN (
        'Complaints (Maker)',
        'MFS 1344 Help Line',
        'MFS 4444 Helpline',
        'Operator user(back end user) maker',
        'Complaints Checker',
        'Operator user(back end user) completer'
    );

План объяснения запроса (SQL Developer): (сохраните файл в формате html и откройте в браузере)

https://drive.google.com/open?id=1KBnhETTzgNLRUh7djyfCN-Wo5QxPZTfb

Важные примечания. Я пытаюсь вставить вывод во временную таблицу. Если вместо этого я вставляю эти данные в новую таблицу, используя create table as. Тот же запрос работает нормально :-(

-- previous columns
   (
        SELECT 
            o.reason
        FROM
            cpsmgt.cps_orderhis o
        WHERE
            o.orderid = t.orderid
    ) reason_of_task,
-- rest of the query.

1 Ответ

0 голосов
/ 07 апреля 2019

Вы пробовали следующую подсказку?

/*+ INDEX(o IDX_CPS_ORDERHIS_3) USE_NL(o t)*/

Возможно, ОПТИМИЗАТОР не выберет правильный индекс и не выберет USE_HASH для плана выполнения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...