0

我正在使用以下查询,其中被引用的表有 5000 万+条记录。通过创建历史表将帮助我获得更好的 CPU 性能?或者除了分区之外还有其他选项吗?或者查询计划调整是唯一的选择?

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

1 回答 1

2

看起来这是一个与在审计表的 version_label 列上收集直方图相关的查询。

我希望您几乎可以肯定不需要存在这样的直方图,并且您可以修改统计信息收集以仅收集此类表上的简单统计信息 - 即。没有直方图。最好的方法是基于您的版本和触发统计信息收集的方式,但如果您需要帮助,请扩展问题以包含这些详细信息或开始另一个问题。

于 2013-03-13T09:39:31.390 回答