`

复合索引生效

 
阅读更多
SQL Server的复合索引学习【转载】
概要
什么是单一索引,什么又是复合索引呢? 何时新建复合索引,复合索引又需要注意些什么呢?本篇文章主要是对网上一些讨论的总结。

一.概念

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

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

同时有两个概念叫做窄索引和宽索引,窄索引是指索引列为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子句中的所有列都被一个非群集索引覆盖,优化程序会识别出这一点,并提供很好的性能。不过,这通常会导致索引过宽,并会过度依赖于优化程序使用该策略的可能性。通常,是用数量更多的窄索引,这对于大量查询来说可以提供更好的性能。
分享到:
评论

相关推荐

    第四章排序查询多表操作[总结].pdf

    索引分为逻辑顺序和物理顺序,前者反映了主控索引生效时的记录排列,后者则指记录的实际存储顺序。在DBF系统中,索引文件有单索引和复合索引两种类型。 单索引文件(.IDX扩展名)只有一个索引项,可以通过`index on...

    MongoDB中唯一索引(Unique)的那些事

    MongoDB支持的索引种类很多,诸如单键索引,复合索引,多键索引,TTL索引,文本索引,空间地理索引等。同时索引的属性可以具有唯一性,即唯一索引。唯一索引用于确保索引字段不存储重复的值,即强制索引字段的唯一性...

    导致索引失效的口诀.pdf

    在复合索引中,索引列的顺序十分的重要。如果不是按照索引列最左列进行查找(使用过程中跨列使用索引字段),都会导致索引失效。例如,CREATE INDEX idx_column1_column2 ON table (column1, column2),在查询的时候,...

    数据库系统及原理及MYSQL应用教程索引实验报告

    索引的类型包括普通索引、唯一索引、复合索引、全文索引等。 2. **掌握创建、更改、删除索引的方法:** - **创建索引**:可以使用`CREATE INDEX`或`ALTER TABLE`语句来创建索引。 - **更改索引**:通常是指对已...

    Mysql(默认使用引擎是innoDB).pdf

    Mysql支持多种类型的索引,包括BTree索引(主要是B+树索引)、Hash索引、复合索引、普通索引、唯一索引、主键索引、空间索引、全文索引等。Hash索引是通过散列函数计算索引值,快速定位数据,但通常适用于等值查询,...

    jt11日常笔记

    - **单表与复合索引**:单表指的是所有数据存储在一个表中,而复合索引是指在多个字段上建立的索引。复合索引的特点是最左前缀特性,即查询时会优先使用索引最左侧的字段进行检索。 - **索引生效情况**:当查询条件...

    Android开发环境中的SQLite性能优化.pdf

    使用索引有四种方式:直接创建索引和间接创建索引、普通索引和唯一性索引、单个索引和复合索引等。使用索引可以提高 SQLite 的查询性能,因为 SQLite 可以快速定位到一组值,而不用扫遍全表。 使用事务和索引是 ...

    30个mysql千万级大数据SQL查询优化技巧详解

    11. **复合索引的使用**:确保使用复合索引的第一个字段进行查询,以使索引生效。 12. **无意义查询**:避免执行无结果的查询,如生成空表,直接使用`CREATE TABLE`语句。 13. **`EXISTS`代替`IN`**:在子查询中,...

    MySQL优化分享.pptx

    - **合理设计索引**:根据查询模式创建复合索引,提高查询速度。 综上所述,MySQL优化涉及多个层面,包括架构理解、SQL语句调整和索引优化。通过对这些方面进行深入研究和实践,我们可以显著提升MySQL数据库的性能...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 第一章 Oracle入门 一、 数据库概述 数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今五十年前。...

    2021-2022计算机二级等级考试试题及答案No.4909.docx

    18. **结构复合索引**:打开带有结构复合索引的数据表,记录顺序保持原样。 19. **Java对象赋值**:Java中对象赋值并不生成新对象,而是复制引用。 20. **Word表格操作**:在表格的最后一个单元格按Tab键会添加新...

    Mysql数据库基本知识文档

    - 索引:提高查询效率的关键,可以创建单列索引、复合索引、唯一索引等。 - 隔离级别:在并发环境下,MySQL提供了不同的事务隔离级别,包括读未提交(READ UNCOMMITTED)、读已提交(READ COMMITTED)、可重复读...

    【mysql知识点整理】— order by 、group by 出现Using filesort原因详解

    - **调整索引**:根据查询需求创建合适的复合索引,确保`ORDER BY`的列在索引的前面。 - **使用子查询或连接**:在某些情况下,通过改变查询结构,可以避免`Using filesort`。 6. **实际业务中的应对策略** 如果...

    数据库规范_.docx

    * 主键(PK)字段如果不是复合主键,统一命名为”ID”,对于这种主键字段被其他表引用(外键)时的名称,不能直接写“ID”,要统一定义好被引用时的名称,并放在 SVN 上。 索引命名规范 在索引命名时,需要遵守...

    2021-2022计算机二级等级考试试题及答案No.16475.docx

    4. 数据库中的有效性规则:当表移出数据库,字段的有效性规则和表的有效性规则不再生效,但结构复合索引文件中的候选索引仍然有效。 5. 输出设备:打印机是常见的输出设备,用于将计算机处理的信息打印在纸上或其他...

    oracle分区培训

    4. **全局索引与局部索引**:了解全局索引对所有分区都有效,而局部索引只对特定分区生效。选择哪种索引取决于查询模式和性能需求。 5. **分区策略**:探讨如何根据业务需求选择合适的分区策略,以及如何随着数据的...

    计算机二级vf考试试题.docx

    移出数据库后,表中字段的有效性规则和表的有效性规则将不再生效,但结构复合索引文件中的候选索引仍然保持有效。 #### 12. 容器类的识别 - **知识点**: 哪些对象属于容器类。 - **解析**: 正确答案是 **D.页框、列...

    laravel执行php artisan migrate报错的解决方法

    例如,可以将一个复合索引分割成两个较短的索引。 2. 使用较长的键前缀:在MySQL 5.7及以上版本中,可以设置innodb_large_prefix为ON,然后将innodb_file_format设置为Barracuda,并确保innodb_file_per_table也为...

Global site tag (gtag.js) - Google Analytics