如何调整这个查询?
How to tune this query?
我正在计算资源成本:
SELECT NVL(sum(WT.TRANSACTION_QUANTITY* WTA.RATE_OR_AMOUNT),0)
-- INTO l_resource_cost
FROM APPS.WIP_TRANSACTION_ACCOUNTS WTA, APPS.WIP_TRANSACTIONS WT
WHERE WTA.TRANSACTION_ID = WT.TRANSACTION_ID
AND WTA.ORGANIZATION_ID = WT.ORGANIZATION_ID
AND WTA.ACCOUNTING_LINE_TYPE =7
AND WTA.WIP_ENTITY_ID = 1757957
AND wt.operation_seq_num = 10;
这些表是 Oracle ebs WIP 表,数据是正确的,但是需要对数千条记录执行此操作。
我该如何调整它?
我可以在这里附上解释计划吗?
首先,学习使用正确的显式 JOIN
语法。简单规则:从不 在 FROM
子句中使用逗号:
SELECT COALESCE(sum(WT.TRANSACTION_QUANTITY * WTA.RATE_OR_AMOUNT), 0)
-- INTO l_resource_cost
FROM APPS.WIP_TRANSACTION_ACCOUNTS WTA JOIN
APPS.WIP_TRANSACTIONS WT
ON WTA.TRANSACTION_ID = WT.TRANSACTION_ID AND
WTA.ORGANIZATION_ID = WT.ORGANIZATION_ID
WHERE WTA.ACCOUNTING_LINE_TYPE = 7 AND WTA.WIP_ENTITY_ID = 1757957 AND
wt.operation_seq_num = 10;
索引将有助于查询。我会推荐:
APPS.WIP_TRANSACTION_ACCOUNTS(ACCOUNTING_LINE_TYPE, WIP_ENTITY_ID, RATE_OR_AMOUNT)
APPS.WIP_TRANSACTIONS(TRANSACTION_ID, ORGANIZATION_ID, operation_seq_num, TRANSACTION_QUANTITY)
.
我正在计算资源成本:
SELECT NVL(sum(WT.TRANSACTION_QUANTITY* WTA.RATE_OR_AMOUNT),0)
-- INTO l_resource_cost
FROM APPS.WIP_TRANSACTION_ACCOUNTS WTA, APPS.WIP_TRANSACTIONS WT
WHERE WTA.TRANSACTION_ID = WT.TRANSACTION_ID
AND WTA.ORGANIZATION_ID = WT.ORGANIZATION_ID
AND WTA.ACCOUNTING_LINE_TYPE =7
AND WTA.WIP_ENTITY_ID = 1757957
AND wt.operation_seq_num = 10;
这些表是 Oracle ebs WIP 表,数据是正确的,但是需要对数千条记录执行此操作。
我该如何调整它?
我可以在这里附上解释计划吗?
首先,学习使用正确的显式 JOIN
语法。简单规则:从不 在 FROM
子句中使用逗号:
SELECT COALESCE(sum(WT.TRANSACTION_QUANTITY * WTA.RATE_OR_AMOUNT), 0)
-- INTO l_resource_cost
FROM APPS.WIP_TRANSACTION_ACCOUNTS WTA JOIN
APPS.WIP_TRANSACTIONS WT
ON WTA.TRANSACTION_ID = WT.TRANSACTION_ID AND
WTA.ORGANIZATION_ID = WT.ORGANIZATION_ID
WHERE WTA.ACCOUNTING_LINE_TYPE = 7 AND WTA.WIP_ENTITY_ID = 1757957 AND
wt.operation_seq_num = 10;
索引将有助于查询。我会推荐:
APPS.WIP_TRANSACTION_ACCOUNTS(ACCOUNTING_LINE_TYPE, WIP_ENTITY_ID, RATE_OR_AMOUNT)
APPS.WIP_TRANSACTIONS(TRANSACTION_ID, ORGANIZATION_ID, operation_seq_num, TRANSACTION_QUANTITY)
.