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

Oracle 索引的三个问题

 2006-08-05 11:51:42 来源:WEB开发网   
核心提示: 2,很多时候,Oracle 索引的三个问题(4),单列索引不如复合索引有效率,3,(此时,这种优化方式被称为 Index only access path)除此之外呢?我们还是来看一个例子吧:在 HP(Oracle 8.1.7) 上执行以下语句:select count(1) from m

2,很多时候,单列索引不如复合索引有效率。

3,用于多表连结的字段,加上索引会很有作用。

那么,在什么情况下单列索引不如复合索引有效率呢?有一种情况是显而易见的,那就是,当sql 语句所查询的列,全部都出现在复合索引中时,此时由于 Oracle 只需要查询索引块即可获得所有数据,当然比使用多个单列索引要快得多。(此时,这种优化方式被称为 Index only access path)

除此之外呢?我们还是来看一个例子吧:

在 HP(Oracle 8.1.7) 上执行以下语句:

select count(1) from mytabs where coid>=130000 and issuedate >= to_date ('2001-07-20', 'yyyy-mm-dd')。

一开始,我们有两个单列索引:I_mytabs1(coid), I_mytabs2(issuedate), 下面是执行情况:

COUNT(1)
----------
6427
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE (Cost=384 Card=1 Bytes=11)
1 0 SORT (AGGREGATE)
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'T_MYTABS' (Cost=384 Card
=126 Bytes=1386)
3 2 INDEX (RANGE SCAN) OF 'I_MYTABS2' (NON-UNIQUE) (Cost=11
Card=126)
Statistics
----------------------------------------------------------
172 recursive calls
1 db block gets
5054 consistent gets
2206 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
5 sorts (memory)
0 sorts (disk)
1 rows processed

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

Tags:Oracle 索引 三个

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