zoukankan      html  css  js  c++  java
  • oracle多个平等的索引

    当SQL语句的执行路径可以使用分布在多个表上的多个索引时, ORACLE会同时使用多个索引并在运行时对它们的记录进行合并, 检索出仅对全部索引有效的记录.

    在ORACLE选择执行路径时,唯一性索引的等级高于非唯一性索引. 然而这个规则只有

    当WHERE子句中索引列和常量比较才有效.如果索引列和其他表的索引类相比较. 这种子句在优化器中的等级是非常低的.

    如果不同表中两个想同等级的索引将被引用, FROM子句中表的顺序将决定哪个会被率先使用. FROM子句中最后的表的索引将有最高的优先级.

    如果相同表中两个想同等级的索引将被引用, WHERE子句中最先被引用的索引将有最高的优先级.

    举例:

         DEPTNO上有一个非唯一性索引,EMP_CAT也有一个非唯一性索引.

         SELECT ENAME,

         FROM EMP

         WHERE DEPT_NO = 20

         AND EMP_CAT = ‘A’;

    这里,DEPTNO索引将被最先检索,然后同EMP_CAT索引检索出的记录进行合并. 执行路径如下:

    TABLE ACCESS BY ROWID ON EMP

        AND-EQUAL

            INDEX RANGE SCAN ON DEPT_IDX

            INDEX RANGE SCAN ON CAT_IDX

  • 相关阅读:
    架构探险笔记3-搭建轻量级Java web框架
    软件工程
    Mysql基础
    Navicat快捷键
    百度搜索的使用技巧
    利用adb截图然后传到电脑
    Div不用float布局
    安卓开发之ScrollView
    安卓开发ScrollView嵌套ListView只显示一行
    修改eclipse的背景色(转载)
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11124891.html
Copyright © 2011-2022 走看看