我正在使用Oracle 12C,我有以下代码
SELECT
d.id,
'Status' "ImportStatus",
p.importid "ImportID",
macid,
p.daterequire "CreateDate",
p.dateimport "DateImPort",
TRANSLATE(p.accrequire USING NCHAR_CS) "CreateBy",
TRANSLATE(p.accimport USING NCHAR_CS) "AccImPort",
0 "isEdit",
employee,
deptid partner,
equipmentid
FROM
(
SELECT
id,
importid,
daterequire,
dateimport,
accrequire,
accimport,
subdeptid employee,
deptid
FROM
tableA
WHERE
estatus = 2
AND createdate BETWEEN to_timestamp('01/01/2019','dd/mm/yyyy') AND to_timestamp('12/02/2019','dd/mm/yyyy')
) p
INNER JOIN tableB d ON d.importid = p.id
TableA具有5m值,TableB具有3m值。
Importid是具有varchar2数据类型的唯一列。 ID是具有数字数据类型的PK。
这是执行计划:
https://i.stack.imgur.com/tR2Q9.png
可以看出,PK中没有索引,导致成本高。 有什么办法可以帮我解决吗?
谢谢!