WEB开发网
开发学院数据库Oracle Oracle 索引的三个问题 阅读

Oracle 索引的三个问题

 2006-08-05 11:51:42 来源:WEB开发网   
核心提示: 可以看到,它读取了7000个数据块来获得所查询的 6000多行,Oracle 索引的三个问题(5),现在,去掉这两个单列索引,Oracle 要使用一个索引,有一些最基本的条件:1,增加一个复合索引I_mytabs_test ( coid, issuedate), 重新执行,结果如下:COU

可以看到,它读取了7000个数据块来获得所查询的 6000多行。

现在,去掉这两个单列索引,增加一个复合索引I_mytabs_test ( coid, issuedate), 重新执行,结果如下:

COUNT(1)
----------
6436
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE (Cost=3 Card=1 Bytes=11)
1 0 SORT (AGGREGATE)
2 1 INDEX (RANGE SCAN) OF 'I_MYTABS_TEST' (NON-UNIQUE) (Cost=3 Card=126 Bytes=1386)
Statistics
----------------------------------------------------------
806 recursive calls
5 db block gets
283 consistent gets
76 physical reads
0 redo size
293 bytes sent via SQL*Net to client
359 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
3 sorts (memory)
0 sorts (disk)
1 rows processed

可以看到,这次只读取了300个数据块。

7000块对300块,这就是在这个例子中,单列索引与复合索引的代价之比。这个例子提示我们, 在许多情况下,单列索引不如复合索引有效率。

可以说,在索引的设置问题上,其实有许多工作可以做。正确地设置索引,需要对应用进行总体的分析。

第三讲、索引再好,不用也是白搭

抛开前面所说的,假设你设置了一个非常好的索引,任何傻瓜都知道应该使用它,但是Oracle 却偏偏不用,那么,需要做的第一件事情,是审视你的 sql 语句。

Oracle 要使用一个索引,有一些最基本的条件:

1, where 子句中的这个字段,必须是复合索引的第一个字段;

上一页  1 2 3 4 5 6  下一页

Tags:Oracle 索引 三个

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接