我有以下条件的 Oracle 视图:
CREATE OR REPLACE FORCE EDITIONABLE VIEW .....
.
.
select * from
(select t1.*,(select t.enddate from (select enddate,empid,
ROW_NUMBER() OVER (PARTITION BY empid ORDER BY enddate desc) as seqnum
from employee t2
where t2.empid=t1.empid) t
where seqnum=1) As enddate_1 from (select * from
(select WED.*,ROW_NUMBER() OVER (PARTITION BY empid ORDER BY startdate desc) as seqnum from
(select t1.*,COUNT(*) OVER (PARTITION BY empid) WDECOUNT from employee t1) WED
where WDECOUNT=1 or WED.startdate <= sysdate)) t1 WHERE seqnum=1);
Wildfly Server 中的 20 或 30 个 Java 集成使用此视图来获取员工数据。
自创建的最后 7 天以来,它需要 6 秒才能返回 50 条记录,现在突然需要 1.5 秒来获取相同的记录(视图 sql 中未进行任何更改)。
检查了 oracle 历史,没有发现任何清除缓存命令或任何类型的锁。
你认为性能突然提高的概率是多少?
(这正在各种笔记本电脑上进行测试,我们发现所有行为都相同(速度缓慢和突然)。对于 Wildfly 连接池存在疑问;但其他表工作正常。
如果完成了某些索引(在历史记录中找不到)或提供了资源,我根本不知道 oracle。如果有人也可以从甲骨文的角度提供帮助)
我用来检查历史记录的 Oracle 查询:
SELECT v.FIRST_LOAD_TIME, CPU_TIME, ELAPSED_TIME, PARSING_SCHEMA_NAME, MODULE, V.* FROM V$SQL V
where PARSING_SCHEMA_NAME = 'MAHTERJEEDATA' order by v.FIRST_LOAD_TIME desc;
Oracle Database 12c 版本 12.1.0.1.0 - 64 位生产