以下查询由产品软件和产品内部执行。DBA 发现此查询正在使用更多的 DB CPU。我们无法调整,因为这是特定于产品的查询,有没有其他选择?考虑我们是否为表中的数据创建历史/存档表将利用以下使用 min 和 max 函数的查询。
SELECT MIN(minbkt),
maxbkt,
SUBSTRB(DUMP(MIN(val), 16, 0, 32), 1, 120) minval,
SUBSTRB(DUMP(MAX(val), 16, 0, 32), 1, 120) maxval,
SUM(rep) sumrep,
SUM(repsq) sumrepsq,
MAX(rep) maxrep,
COUNT(*) bktndv,
SUM(CASE
WHEN rep = 1 THEN
1
ELSE
0
END) unqrep
FROM (SELECT val,
MIN(bkt) minbkt,
MAX(bkt) maxbkt,
COUNT(val) rep,
COUNT(val) * COUNT(val) repsq
FROM (SELECT
/*+ no_parallel(t) no_parallel_index(t) dbms_stats cursor_sharing_exact use_weak_name_resl dynamic_sampling(0) no_monitoring */
"VERSION_LABEL" val,
NTILE(75) OVER(ORDER BY NLSSORT("VERSION_LABEL", 'NLS_SORT = binary')) bkt
FROM "User"."AUDITTRAIL" t
WHERE "VERSION_LABEL" IS NOT NULL)
GROUP BY val)
GROUP BY maxbkt
ORDER BY maxbkt