Я пытаюсь повысить производительность SQL-запроса к базе данных Oracle 10g. У меня есть следующие два запроса:
Запрос 1
SELECT DISTINCT
WMS_EVENT_LOG.LOG_ID,
WMS_EVENT_LOG.EVENT_ARG4,
WMS_EVENT_LOG.EVENT_TYPE,
WMS_EVENT_LOG.EVENT_ARG1,
WMS_EVENT_LOG.EVENT_ARG3,
WMS_EVENT_LOG.PROD_ITEM_ID,
TRUNC(WMS_EVENT_LOG.LOG_DATE) AS LOG_DATE,
WMS_EVENT_LOG.PALLET_ID,
WMS_EVENT_LOG.LOG_USER,
WMS_EVENT_LOG.POSTED_TO_KCAT,
POSTEDWMSTRANS.POSTTRAN,
DECODE(POSTEDWMSTRANS.POSTTRAN, 'Y', POSTEDWMSTRANS.CMNT, WMS_EVENT_LOG.EVENT_ARG3) AS CMNT --cmnt = comment
FROM
VMR_WMSEVENTLOG WMS_EVENT_LOG,
VM_ADJUST_REASON ADJUST_REASON,
(
SELECT
INVENTORY.BOM_TYPE AS POSTTRAN,
INVENTORY.PROD_ITEM_ID,
INVENTORY.CMNT,
INVENTORY.WMSLINK
FROM
VR_BOM INVENTORY
WHERE
INVENTORY.BOM_TDATE >= TO_DATE(:report_start_date, 'YYYY/MM/DD') - 15 AND
INVENTORY.BOM_TDATE < TO_DATE(:report_end_date, 'YYYY/MM/DD') + 15 AND
INVENTORY.WMSLINK IS NOT NULL AND
INVENTORY.BOM_TYPE <> 'HLD'
) POSTEDWMSTRANS
WHERE
WMS_EVENT_LOG.LOG_DATE >= TO_DATE(:report_start_date, 'YYYY/MM/DD') AND
WMS_EVENT_LOG.LOG_DATE < TO_DATE(:report_end_date, 'YYYY/MM/DD') AND
WMS_EVENT_LOG.EVENT_TYPE = 31 AND
ADJUST_REASON.ADJUST_REASON_CODE NOT IN ('SPL') AND
ADJUST_REASON.ADJUST_REASON_CODE = WMS_EVENT_LOG.EVENT_ARG1 AND (
WMS_EVENT_LOG.EVENT_ARG1 <> 'MOV' AND
WMS_EVENT_LOG.EVENT_ARG2 = 'ADJUST'
) AND
WMS_EVENT_LOG.PROD_ITEM_ID = POSTEDWMSTRANS.PROD_ITEM_ID(+) AND
WMS_EVENT_LOG.EVENT_ARG4 = POSTEDWMSTRANS.WMSLINK(+)
Запрос 2
--VARIABLE report_start_date VARCHAR
--VARIABLE report_end_date VARCHAR
SELECT DISTINCT
WMS_EVENT_LOG.LOG_ID,
WMS_EVENT_LOG.EVENT_ARG4,
WMS_EVENT_LOG.EVENT_TYPE,
WMS_EVENT_LOG.EVENT_ARG1,
WMS_EVENT_LOG.EVENT_ARG3,
WMS_EVENT_LOG.PROD_ITEM_ID,
TRUNC(WMS_EVENT_LOG.LOG_DATE) AS LOG_DATE,
WMS_EVENT_LOG.PALLET_ID,
WMS_EVENT_LOG.LOG_USER,
WMS_EVENT_LOG.POSTED_TO_KCAT,
POSTEDWMSTRANS.POSTTRAN,
DECODE(POSTEDWMSTRANS.POSTTRAN, 'Y', POSTEDWMSTRANS.CMNT, WMS_EVENT_LOG.EVENT_ARG3) AS CMNT --cmnt = comment
FROM
VMR_WMSEVENTLOG WMS_EVENT_LOG,
VM_ADJUST_REASON ADJUST_REASON,
(
SELECT
INVENTORY.BOM_TYPE AS POSTTRAN,
INVENTORY.PROD_ITEM_ID,
INVENTORY.CMNT,
INVENTORY.WMSLINK
FROM
VR_BOM INVENTORY
WHERE
INVENTORY.BOM_TDATE >= TO_DATE(:report_start_date, 'YYYY/MM/DD') - 15 AND
INVENTORY.BOM_TDATE < TO_DATE(:report_end_date, 'YYYY/MM/DD') + 15 AND
INVENTORY.WMSLINK IS NOT NULL AND
INVENTORY.BOM_TYPE <> 'HLD'
) POSTEDWMSTRANS
WHERE
WMS_EVENT_LOG.LOG_DATE >= TO_DATE(:report_start_date, 'YYYY/MM/DD') AND
WMS_EVENT_LOG.LOG_DATE < TO_DATE(:report_end_date, 'YYYY/MM/DD') AND
WMS_EVENT_LOG.EVENT_TYPE = 31 AND
ADJUST_REASON.ADJUST_REASON_CODE NOT IN ('SPL') AND
ADJUST_REASON.ADJUST_REASON_CODE = WMS_EVENT_LOG.EVENT_ARG1 AND (
WMS_EVENT_LOG.EVENT_ARG1 <> 'MOV' AND
WMS_EVENT_LOG.EVENT_ARG2 = 'ADJUST'
) AND
WMS_EVENT_LOG.PROD_ITEM_ID = POSTEDWMSTRANS.PROD_ITEM_ID(+) AND
WMS_EVENT_LOG.EVENT_ARG4 = POSTEDWMSTRANS.WMSLINK(+)
Как видите, единственная разница между двумя запросами — это комментарии вверху.
По какой-то причине, когда я запускаю query 2
несколько раз в разработчике PL/SQL, он завершается менее чем за секунду. Когда я запускаю query 1
несколько раз в одной и той же среде, это занимает 15 секунд.
Я проверил возвращенные строки, и обе возвращают одинаковое количество строк с одинаковыми данными.
Почему запрос 2 завершается быстрее?
Я полагаю, что это может быть настройка в PL/SQL Developer, которая дает мне ложную информацию.
Примечание
Все это изначально было написано для 8i, дорабатываю для 10g.
Explained
. Я также получил сообщение'PLAN_TABLE' is old version
- person Dodzi Dzakuma   schedule 23.07.2014