Chinaunix首页 | 论坛 | 博客
  • 博客访问: 91310922
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: DB2/Informix

2008-05-31 18:27:24

索引自连接

索引自连接是这样一类索引,如果复合索引中的主要列具有大量重复内容,而非主要列具有较好的选择性,则将对查询进行优化。

在 IDS 的早期版本中,优化器将对符合搜索条件的复合索引进行全方位扫描,或者,如果主要列都不满足条件,则执行连续扫描。

索引自连接将对高度重复的主要列搜索惟一组合,然后对搜索得到的惟一组合执行较小的查询,对更具选择性的非主要列进行过滤。该表在逻辑上执行自连接。

除索引自连接以外,还提供了两种新的指令访问方法:

  • INDEX_SJ:强制优化器执行索引自连接
  • AVOID_INDEX_SJ:阻止优化器执行索引自连接

例如,以下表为例,其中的 col1 和 col2 列具有大量重复,col3 选择性较好,而这三个列(col1、col2、col3)之上定义了一个复合索引(idx1):



                    
        CREATE TABLE tab1 (
        col1  int,
        col2  int,
        col3  int);
        
        CREATE INDEX idx1 ON tab1(col1,col2,col3);

执行以下查询:



        SELECT * FROM TAB1
        WHERE col1 >= 1  AND col1 <= 2
        AND   col2 >= 2  AND col2 <= 4
        AND   col3 >= 40 AND col3 <= 50;
      

首先,将对主要列 col1 和 col2(高度重复)执行索引扫描,以获得惟一组合。然后对于得到的惟一组合,使用过滤器 (col1 = col1, col2 = col2, col3 >= 40, col3 <= 50) 执行索引扫描。可以将这种方法视作使用相同索引执行两次索引扫描。



自索引图


                    
        QUERY:
        ------
        SELECT * FROM TAB1
        WHERE col1 >= 1  AND col1 <= 2
        AND   col2 >= 2  AND col2 <= 4
        AND   col3 >= 40 AND col3 <= 50
        
        Estimated Cost: 37
       Estimated # of Rows Returned: 66
        
        1) informix.tab1: INDEX PATH
        
        (1) Index Keys: col1 col2 col3   (Key-Only)  (Serial, fragments: ALL)
        Index Self Join Keys (col1 col2 )
        Lower bound: informix.tab1.col1 >= 1 AND (informix.tab1.col2 >= 2 )
        Upper bound: informix.tab1.col1 <= 2 AND (informix.tab1.col2 <= 4 )
        
        Lower Index Filter: (informix.tab1.col1 = informix.tab1.col1 
        AND informix.tab1.col2 = informix.tab1.col2 ) 
        AND informix.tab1.col3 >= 40
        
        Upper Index Filter: informix.tab1.col3 <= 50
        Index Key Filters:  (informix.tab1.col2 <= 4 ) AND
        (informix.tab1.col2 >= 2 )
        
        
        Query statistics:
        -----------------
        
        Table map :
        ----------------------------
        Internal name     Table name
        ----------------------------
        t1                tab1
        
        type     table  rows_prod  est_rows  rows_scan  time       est_cost
        -------------------------------------------------------------------
        scan     t1     66         66        66         00:00:00   37 
                



自索引图


                    
        QUERY:
        ------
        SELECT {+AVOID_INDEX_SJ(TAB1 IDX1)} * FROM TAB1
        WHERE col1 >= 1 AND col1 <= 2
        AND   col2 >= 2 AND col2 <= 4
        AND   col3 >= 40 AND col3 <= 50
        
        
        DIRECTIVES FOLLOWED:
        AVOID_INDEX_SJ ( tab1 idx1 )
        DIRECTIVES NOT FOLLOWED:
        
        Estimated Cost: 208144 
       Estimated # of Rows Returned: 66
        
        1) informix.tab1: INDEX PATH
        
        (1) Index Keys: col1 col2 col3   (Key-Only)  (Serial, fragments: ALL)
        Lower Index Filter: informix.tab1.col1 >= 1 
        AND (informix.tab1.col2 >= 2 ) 
        AND (informix.tab1.col3 >= 40 )
        
        Upper Index Filter: informix.tab1.col1 <= 2 
        AND (informix.tab1.col3 <= 50 ) 
        AND (informix.tab1.col2 <= 4 )
        
        Index Key Filters:  (informix.tab1.col3 <= 50 ) AND
        (informix.tab1.col2 <= 4 ) AND
        (informix.tab1.col2 >= 2 ) AND
        (informix.tab1.col3 >= 40 )
        
        
        Query statistics:
        -----------------
        
        Table map :
        ----------------------------
        Internal name     Table name
        ----------------------------
        t1                tab1
        
        type     table  rows_prod  est_rows  rows_scan  time       est_cost
        -------------------------------------------------------------------
        scan     t1     66         66        3500011    00:00:13   208144
阅读(2618) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~