DBMS_SPACE.OBJECT_GROWTH_TREND仅返回历史快照数据,不具备预测能力;真正趋势建模需结合DBA_HIST_SEG_STAT与REGR_SLOPE线性拟合,并注意SYSAUX异常干扰。
dbms_space.object_growth_trend 不能直接预测未来增长,它只返回历史快照点的空间用量,没有时间序列建模能力;真要预估趋势,得靠 dba_hist_seg_stat 或 dba_hist_tbspc_space_usage + 线性拟合。
这个函数名字带“growth trend”,容易让人误以为能外推。实际它只是把 DBA_HIST_SEG_STAT 中已有的历史 space_used 值按 snap_id 拉出来,每行一个快照点,字段包括 OBJECT_NAME、SPACE_USED(字节)、SNAP_TIME——但没提供任何斜率、增长率或未来估算。你拿到的是一堆过去的数据点,不是模型。
OBJECT_GROWTH_TREND 不接受时间范围参数,也不能指定步长或预测天数space_used;12c 及以前常为 NULL,查出来全是空dba_hist_wr_control.retention 控制),想看 30 天趋势得先确认 retention 是否调大要算某张表未来 30 天可能涨多少,必须自己构造时间序列:取两个快照之间 space_used 的差值,再用 Oracle 内置线性回归函数拟合。DBMS_SPACE 包不参与这个过程。
SELECT owner, object_name, snap_id, space_used, snap_time FROM dba_hist_seg_stat WHERE owner = 'SCOTT' AND object_name = 'EMP' AND snap_time >= SYSDATE - 30
TRUNC(snap_time) 归一化日期,再转成数字轴(如 TRUNC(snap_time) - DATE '2026-01-01'),避免日期计算溢出space_used(防漏掉夜间批量插入后的峰值),再用 REGR_SLOPE(space_used, dt_num) 算字节/天这两个过程用来预估“刚建表/索引时需要多少空间”,和后续增长完全无关。它们基于当前统计信息、字段定义、行数假设做一次性计算,不感知 DML 流量或历史增速。
CREATE_TABLE_COST 需要传入 avg_row_size 和 row_count,如果业务行数每月翻倍,这个估算就迅速失效CREATE_INDEX_COST 强烈依赖 dbms_stats.gather_table_stats 结果,统计过期时估算偏差可达 3–5 倍used_bytes(实际数据+块头+pctfree)和 alloc_bytes(含 extent 分配粒度),但都不含索引分裂、LOB 段扩展、IOT 溢出等运行时开销CREATE_TABLE_COST 的结果减去昨天的,来倒推“日增”,那是错的——它根本不记录历史,也不支持增量计算当你发现 DBA_HIST_SEG_STAT 或 DBA_HIST_TBSPC_SPACE_USAGE 数据异常(比如某天突增 50GB),大概率不是业务表在涨,而是 SYSAUX 里的 AWR 组件失控。WRH$_ACTIVE_SESSION_HISTORY 占满 SYSAUX 后,不仅让空间趋势失真,还会拖慢所有 AWR 查询。
SELECT COUNT(*) FROM WRH$_ACTIVE_SESSION_HISTORY,超 200 万行基本可锁定问题DELETE,先调小 baseline 窗口:EXEC DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS(retention => 7 * 24 * 60)
EXEC DBMS_WORKLOAD_REPOSITORY.DROP_SNAPSHOT_RANGE
dba_hist_tbspc_space_usage,看 SYSAUX 的 tablespace_usedsize 是否回落——否则趋势分析全白做