`

SQL Server的复合索引学习

阅读更多

转自:http://www.cnblogs.com/bccu/archive/2007/08/14/855487.html

 

概要
什么是单一索引,什么又是复合索引呢? 何时新建复合索引,复合索引又需要注意些什么呢?本篇文章主要是对网上一些讨论的总结。

一.概念

单一索引是指索引列为一列的情况,即新建索引的语句只实施在一列上。

用户可以在多个列上建立索引,这种索引叫做复合索引(组合索引)。复合索引的创建方法与创建单一索引的方法完全一样。但复合索引在数据库操作期间所需的开销更小,可以代替多个单一索引。当表的行数远远大于索引键的数目时,使用这种方式可以明显加快表的查询速度。

同时有两个概念叫做窄索引和宽索引,窄索引是指索引列为1-2列的索引,如果不特殊说明的话一般是指单一索引。宽索引也就是索引列超过2列的索引。

设计索引的一个重要原则就是能用窄索引不用宽索引,因为窄索引往往比组合索引更有效。拥有更多的窄索引,将给优化程序提供更多的选择余地,这通常有助于提高性能。

二.使用

创建索引 
create index idx1 on table1(col1,col2,col3)  
查询
select * from table1 where col1= A and col2= B and col3 = C

这时候查询优化器,不在扫描表了,而是直接的从索引中拿数据,因为索引中有这些数据,这叫覆盖式查询,这样的查询速度非常快。   

三.注意事项

1.何时是用复合索引
在where条件中字段用索引,如果用多字段就用复合索引。一般在select的字段不要建什么索引(如果是要查询select col1 ,col2, col3 from mytable,就不需要上面的索引了)。根据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.复合索引会替代单一索引么?
很多人认为只要把任何字段加进聚集索引,就能提高查询速度,也有人感到迷惑:如果把复合的聚集索引字段分开查询,那么查询速度会减慢吗?带着这个问题,我们来看一下以下的查询速度(结果集都是25万条数据):(日期列fariqi首先排在复合聚集索引的起始列,用户名neibuyonghu排在后列)

IDX1:create   index   idx1   on   Tgongwen(fariqi,neibuyonghu)  


(1)select gid,fariqi,neibuyonghu,title from Tgongwen
where fariqi>'2004-5-5'

查询速度:2513毫秒

(2)select gid,fariqi,neibuyonghu,title from Tgongwen
where fariqi>'2004-5-5' and neibuyonghu='办公室'

查询速度:2516毫秒

(3)select gid,fariqi,neibuyonghu,title from Tgongwen
where neibuyonghu='办公室'

查询速度:60280毫秒

从以上试验中,我们可以看到如果仅用聚集索引的起始列作为查询条件和同时用到复合聚集索引的全部列的查询速度是几乎一样的,甚至比用上全部的复合索引列还要略快(在查询结果集数目一样的情况下);而如果仅用复合聚集索引的非起始列作为查询条件的话,这个索引是不起任何作用的。当然,语句1、2的查询速度一样是因为查询的条目数一样,如果复合索引的所有列都用上,而且查询结果少的话,这样就会形成“索引覆盖”,因而性能可以达到最优。同时,请记住:无论您是否经常使用聚合索引的其他列,但其前导列一定要是使用最频繁的列。

[参考: 查询优化及分页算法方案 http://blog.csdn.net/chiefsailor/archive/2007/05/28/1628339.aspx]

4.需要在同一列上同时建单一索引和复合索引么?
试验: sysbase   5.0   表table1   字段:col1,col2,col3  

试验步骤:  
(1)建立索引idx1   on   col1  
  执行select   *   from   table1   where   col1=A     使用idx1  
  执行select   *   from   table1   where   col1=A   and   col2=B   也使用idx1  

(2)删除索引idx1,然后建立idx2   on   (col1,col2)复合索引  
  执行以上两个查询,也都使用idx2  

(3)如果两个索引idx1,idx2都存在  
  并不是   where   col1='A'用idx1;where   col1=A   and   col2=B  用idx2。  
  其查询优化器使用其中一个以前常用索引。要么都用idx1,要么都用idx2.  
   
由此可见,
(1)对一张表来说,如果有一个复合索引 on   (col1,col2),就没有必要同时建立一个单索引 on col1。
(2)如果查询条件需要,可以在已有单索引
 on col1的情况下,添加复合索引on   (col1,col2),对于效率有一定的提高。
(3)
同时建立多字段(包含5、6个字段)的复合索引没有特别多的好处,相对而言,建立多个窄字段(仅包含一个,或顶多2个字段)的索引可以达到更好的效率和灵活性。



5. 一定需要覆盖性查询么?
通常最好不要采用一个强调完全覆盖查询的策略。如果Select子句中的所有列都被一个非群集索引覆盖,优化程序会识别出这一点,并提供很好的性能。不过,这通常会导致索引过宽,并会过度依赖于优化程序使用该策略的可能性。通常,是用数量更多的窄索引,这对于大量查询来说可以提供更好的性能。

分享到:
评论

相关推荐

    SQLServer的复合索引学习.docx

    SQL Server的复合索引,是数据库管理中一种重要的性能优化技术。复合索引,也称为组合索引,是指在一个索引中包含多个列,相比于单一索引,它可以在某些特定查询场景下提供更快的检索速度。 单一索引,顾名思义,是...

    SQL Server 索引中include的魅力(具有包含性列的索引)

    * 复合索引:包含两个或者多个字段的索引。 * 非键列:键列就是在索引中所包含的列,当然非键列就是该索引之外的列了。 摘要 1:在 SQL Server 2005 中,可以通过将非键列添加到非聚集索引的叶级别来扩展非聚集索引...

    SQL SERVER建立索引.pdf

    - **复合索引**:可以同时基于多个列创建索引,称为复合索引。复合索引不仅可以基于同一表中的不同列创建,还可以创建复合的聚簇索引。例如,如果需要根据“姓”和“名”两个字段一起查询,可以创建一个包含这两个...

    SQL Server 2000完结篇系列之七:SQL Server 2000索引优化详解

    2. 组合索引:为多个列创建复合索引,适用于多条件查询。 3. 考虑索引宽度:索引列的长度会影响索引大小,过宽的索引可能会占用过多空间且降低性能。 4. 避免过度索引:过多的索引会增加数据库维护成本,应根据实际...

    SQLServer索引设计经验谈

    - **相关性**:对于复合索引,应考虑各列间的相关性,确保索引能够覆盖尽可能多的查询需求。 - **范围查询**:在包含范围查询的索引中,应将范围条件列放在前面。 #### 3. 设置适当的填充因子 - **定义**:填充...

    sql server学习手册以及t-sql优化方案.zip

    2. 索引策略:合理创建和维护索引,包括复合索引、覆盖索引、索引分区等,以提升查询速度。 3. 数据库设计:遵循正常化原则,避免数据冗余,合理设计表结构,以降低数据更新时的副作用。 4. 内存优化:调整数据库...

    sql server 索引设计与优化

    - **优化策略**:文章提供了如何设计非聚簇索引以优化查询性能的方法,包括如何选择索引字段、何时使用复合索引等。 - **上下篇**:通过两篇文章的形式,从基础概念入手,逐步深入到高级技巧的应用。 #### 添加非聚...

    SQL Server数据库索引设计的研究.pdf

    - **复合索引**:当单个列的区分度不高时,可以考虑使用多列的复合索引。 3. **索引最佳实践** - **索引维护**:定期进行重建和重新组织索引,以优化存储结构并修复碎片。 - **覆盖索引**:创建包含查询所需所有...

    SQL Server中索引的建立与分析.pdf

    例如,在订单信息表中,如果经常需要根据数量和订货日期进行查询,那么在这些字段上建立非唯一且非聚集的复合索引将有助于提升相关查询的性能。 总结来说,索引是优化SQL Server数据库性能的关键工具之一。它不仅...

    详解sqlserver查询表索引

    同时,考虑复合索引,即包含多个字段的索引,这在多个字段一起被查询时能提供更好的性能。 在Oracle中,你可以使用类似下面的查询来获取用户表的索引信息: ```sql select index_name, index_type, table_name ...

    SQL Server Mobile 开发基础

    在SQL Server Mobile中,可以创建单列或复合索引,以及唯一索引。 8. **事务处理** SQL Server Mobile支持事务处理,保证数据的一致性和完整性。BEGIN TRANSACTION、COMMIT和ROLLBACK语句用于控制事务的生命周期。...

    SQL Server索引设计和调优技术大全

    - **复合索引**:当单个列不足以支持高效的查询时,可以考虑创建包含多个列的复合索引。 - **统计信息**:定期更新索引的统计信息,以确保查询计划器能够做出准确的决策。 #### 五、创建和优化索引 - **创建索引的...

    关于SQL Server与VFP索引的研究.pdf

    复合索引文件分为结构复合索引文件和独立复合索引文件,分别与所属表同名和异名。为了使用索引,需要预先打开索引文件,结构复合索引文件因其可以随表自动打开的便利性而受到开发人员的青睐。 相比较之下,SQL ...

    SQL Server索引使用的几个误区.pdf

    标题中提到的“SQL Server索引使用的几个误区.pdf”指明了文档的主题是关于SQL Server数据库中索引的使用,同时强调了一些常见错误和误解。这部分内容通常会涉及索引在数据库中的作用、种类以及如何正确使用索引来...

    sql server 2000

    6. 索引创建:考生需创建两个复合索引,分别在"图书基本信息表"的"出版单位"和"作者"字段,以及"读者基本信息表"的"所在部门"和"姓名"字段。这使用CREATE INDEX语句完成,例如: ```sql CREATE INDEX 索引_出版单位_...

    SQLServer索引的优化

    综上所述,通过建立有用的索引、优化WHERE子句以及合理创建复合索引,可以有效地提升SQL Server的查询速度和整体性能。这些策略不仅适用于本文提到的具体案例,也可以推广应用于更广泛的数据库设计和优化场景中。

    sqlserver 2005 主外键-复合主键

    ### SQL Server 2005 中创建复合主键 在SQL Server 2005中,创建包含复合主键的表可以通过以下方式实现: ```sql CREATE TABLE test ( a int, b varchar(10), CONSTRAINT [PK_tbl_ClassUDF] PRIMARY KEY ...

    多列复合索引的使用 绕过微软sql server的一个缺陷

    在SQL Server中,多列复合索引是一种优化查询性能的重要工具。这种索引由两个或更多列组成,目的是为了加速对这些列组合的查询。在处理复合索引时,理解其工作原理和潜在的局限性至关重要,特别是对于大型数据表来说...

    SQL_Server索引设计和调优技巧大全

    - **合理使用复合索引**:当单个索引不足以满足查询需求时,考虑使用包含多个列的复合索引。 #### 四、索引优化 ##### 4.1 索引的能与不能 - **能**:加速查询速度,减少I/O操作。 - **不能**:解决所有性能问题;...

Global site tag (gtag.js) - Google Analytics