• 复合索引(组合索引)


    用户可以在多个列上建立索引,这种索引叫做复合索引(组合索引)。

    1.何时是用复合索引
    在where条件中字段用索引,如果用多字段就用复合索引。比如在查询地址的时候,经常要求输入省,市信息,如果同时在省,市上建立索引,将会提高查询速度。

     

    2.对于复合索引,在查询使用时,最好将条件顺序按找索引的顺序,这样效率最高。如:
    IDX1:create index idx1 on table1(col2,col3,col5)
    "select * from table1 where col2=A and col3=B and col5=D" 索引效果明显
    如果是"select * from table1 where col3=B and col2=A and col5=D"
    或者是"select * from table1 where col3=B"将不会使用索引,或者效果不明显

     

    3.复合索引会替代单一索引么?

    复合索引IDX1:create index idx1 on table1(col1,col2) 单一索引IDX2:create index idx2 on table1(col1)
    单一索引IDX2作为查询条件和复合索引IDX1作为查询条件的查询速度是几乎一样的,甚至比用复合索引IDX1还要略快(在查询结果集数目一样的情况下);而如果仅用复合聚集索引的非起始列(col2)作为查询条件的话,复合索引IDX1是不起任何作用的。对一张表来说,如果有一个复合索引 on (col1,col2),就没有必要同时建立一个单索引 on col1。如果查询条件需要,可以在已有单索引 on col1的情况下,添加复合索引on (col1,col2),对于效率有一定的提高。

     
  • 相关阅读:
    HttpContext.Current.Cache过期使用方法
    IE11下使用IE8
    Sqldbx连接oracle
    XML序列之System.Xml.Serialization
    怎样设置域名带www和不带www都可以访问
    log4net一些配置说明
    部署wcf到IIS时的问题
    spring.net学习(一) 搭建环境,实例化spring.net容器。
    WPF 多语言实现
    C# 类型转换问题
  • 原文地址:https://www.cnblogs.com/frankyou/p/4667107.html
Copyright © 2020-2023  润新知