14

我在 Oracle 环境中有一些表,我发现它们可以从新索引中受益。但是,它们是大表,从 1M 寄存器到 300M 寄存器,所以我会首先尝试估计创建索引需要多少时间,所以我至少会知道它需要的数量级(小时、天、周)?

是否有一些启发式/oracle 函数/经验法则可以帮助我解决这个问题?

4

2 回答 2

10

Oracle 可以使用以下命令估计索引创建时间和索引大小EXPLAIN PLAN

示例架构

--Create a table with 1 million rows.
drop table table1;
create table table1(a number);
insert into table1 select level from dual connect by level <= 1000000;
--Gather statistics.
begin
    dbms_stats.gather_table_stats(user, 'table1');
end;
/
--Estimate index creation and size.
explain plan for create index table1_idx on table1(a);
select * from table(dbms_xplan.display);

结果

Plan hash value: 290895522

-------------------------------------------------------------------------------------
| Id  | Operation              | Name       | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------
|   0 | CREATE INDEX STATEMENT |            |  1000K|  4882K|   683   (2)| 00:00:10 |
|   1 |  INDEX BUILD NON UNIQUE| TABLE1_IDX |       |       |            |          |
|   2 |   SORT CREATE INDEX    |            |  1000K|  4882K|            |          |
|   3 |    TABLE ACCESS FULL   | TABLE1     |  1000K|  4882K|   254   (5)| 00:00:04 |
-------------------------------------------------------------------------------------

Note
-----
   - automatic DOP: skipped because of IO calibrate statistics are missing
   - estimated index size: 24M bytes

笔记

我系统上的实际创建时间为 2.5 秒,而估计为 10 秒。但是,如果您只是在寻找一个数量级的估计,那仍然足够好。准确性取决于具有准确的表统计信息以及良好的系统统计信息。(但是在收集系统统计信息之前要小心,它可能会影响很多执行计划!)您可以通过手动修改来进一步摆弄设置sys.aux_stats$。这是少数几个可以修改的 SYS 表之一,尽管您仍然需要小心。

于 2015-06-18T19:30:29.350 回答
9

确实有太多因素需要考虑,例如机器速度、内存等可能会影响创建时间。此外,数据本身的性质可能会对创建时间产生重大影响。

我要做的是选择一个较大的表,在上面创建一个索引,看看需要多长时间。然后,花点时间除以表中的行数,这应该会给你一个粗略的指标来预测预期的结果。再次注意,这并不精确,但这只是您可以使用的经验法则。它会有很大的不同,因为有些表有更多的列,更少的稀疏列值等,但这是一个起点。

Ex.  It takes 3600 seconds to create a index on table X, which has 3 million rows.
So the metric is 3600 / 3,000,000 = 0.0012 seconds per row.

So if table Y has 8 million rows, you could expect
.0012 * 8,000,000 = 9600 seconds (or 160 minutes) to create the index.
于 2010-06-18T17:51:20.090 回答