0

以下查询由产品软件和产品内部执行。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
4

0 回答 0