zoukankan      html  css  js  c++  java
  • 复合索引(组合索引)

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

    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),对于效率有一定的提高。

     
  • 相关阅读:
    TTVNC 2.0 发布了
    软件收费问题,目前没有限制, 全部免费
    为什么服务器端要确认才能连接通过
    关于transfer file功能的使用?
    同一台机器上测试会出现很多黑块
    TTVNC 设计理念
    TTVNC 2.2发布
    redis连接池 jedis2.9.0.jar+commonspool22.4.2.jar
    Calendar add 方法 和set方法
    jar包读取包内properties文件
  • 原文地址:https://www.cnblogs.com/frankyou/p/4667107.html
Copyright © 2011-2022 走看看