热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用索引的误区之一:没有使用复合索引_sqlserver

使用索引的误区之一:没有使用复合索引的前导列导致查询不使用索引在oracle中,我们经常以为建立了索引,sql查询的时候就会如我们所希望的那样使用索引,事实上,oracle只会在一定条件下使用索引

使用索引的误区之一:没有使用复合索引的前导列导致查询不使用索引
在oracle中,我们经常以为建立了索引,sql查询的时候就会如我们所希望的那样使用索引,事实上,oracle只会在一定条件下使用索引,这里我们总结数第一点:oracle会在条件中包含了前导列时使用索引,即查询条件中必须使用索引中的第一个列,请看下面的例子

SQL> select * from tab;

 

http://www.gaodaima.com/35914.html使用索引的误区之一:没有使用复合索引_sqlserver

TNAME                          TABTYPE  CLUSTERID

—————————— ——- ———-

BONUS                          TABLE

DEPT                           TABLE

DUMMY                          TABLE

EMP                            TABLE

SALGRADE                       TABLE

 

建立一个联合索引(注意复合索引的索引列顺序)

SQL> create index emp_id1 on emp(empno,ename,deptno);

 

Index created

 

建立一个单键索引

SQL> create index emp_id2 on emp(sal);

 

Index created

 

 

SQL> select table_name,index_name from user_indexes

  2  where table_name=’EMP’;

 

TABLE_NAME                     INDEX_NAME

—————————— ——————————

EMP                            EMP_ID1

EMP                            EMP_ID2

 

SQL> SELECT * FROM USER_IND_COLUMNS

  2  /

 

INDEX_NAME                     TABLE_NAME                     COLUMN_NAME                                                                      COLUMN_POSITION COLUMN_LENGTH CHAR_LENGTH DESCEND

—————————— —————————— ——————————————————————————– ————— ————- ———– ——-

EMP_ID1                        EMP                            EMPNO                                                                                          1            22           0 ASC

EMP_ID1                        EMP                            ENAME                                                                                          2            10          10 ASC

EMP_ID1                        EMP                            DEPTNO                                                                                         3            22           0 ASC

EMP_ID2                        EMP                            SAL                                                                                            1            22           0 ASC

 

下面的查询由于没有使用到复合索引的前导列,所以没有使用索引

 select job, empno from emp where ename=’RICH’;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

——————————————————————–

| Id  | Operation            |  Name       | Rows  | Bytes | Cost  |

——————————————————————–

|   0 | SELECT STATEMENT     |             |       |       |       |

|*  1 |  TABLE access FULL   | EMP         |       |       |       |

——————————————————————–

Predicate Information (identified by operation id):

—————————————————

   1 – filter(“EMP”.”ENAME”=’RICH’)

Note: rule based optimization

 

14 rows selected

 

 

下面的查询也由于没有使用到复合索引的前导列,所以没有使用索引

select job, empno from emp where deptno=30;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

——————————————————————–

| Id  | Operation            |  Name       | Rows  | Bytes | Cost  |

——————————————————————–

|   0 | SELECT STATEMENT     |             |       |       |       |

|*  1 |  TABLE ACCESS FULL   | EMP         |       |       |       |

——————————————————————–

Predicate Information (identified by operation id):

—————————————————

   1 – filter(“EMP”.”DEPTNO”=30)

Note: rule based optimization

 

14 rows selected

 

 

 

下面的查询使用了复合索引中的前导列,所以查询走索引了

select job, empno from emp where empno=7777;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

—————————————————————————

| Id  | Operation                   |  Name       | Rows  | Bytes | Cost  |

—————————————————————————

|   0 | SELECT STATEMENT            |             |       |       |       |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP         |       |       |       |

|*  2 |   INDEX RANGE SCAN          | EMP_ID1     |       |       |       |

—————————————————————————

Predicate Information (identified by operation id):

—————————————————

   2 – access(“EMP”.”EMPNO”=7777)

Note: rule based optimization

 

15 rows selected

 

 

 

 

下面的查询使用了复合索引中的第一列和第二列,所以查询走索引了

select job, empno from emp where empno=7777 and ename=’RICH’;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

—————————————————————————

| Id  | Operation                   |  Name       | Rows  | Bytes | Cost  |

—————————————————————————

|   0 | SELECT STATEMENT            |             |       |       |       |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP         |       |       |       |

|*  2 |   INDEX RANGE SCAN          | EMP_ID1     |       |       |       |

—————————————————————————

Predicate Information (identified by operation id):

—————————————————

   2 – access(“EMP”.”EMPNO”=7777 AND “EMP”.”ENAME”=’RICH’)

Note: rule based optimization

 

15 rows selected

 

 

 

使用了复合索引的全部列,所以走索引了,另外由于选了了索引中没有包含的列(job),

所以进行索引全表扫描得到满足条件的rowid后,还要到表中检索相应的行

select job, empno from emp where empno=7777 and ename=’RICH’ and deptno=30;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

—————————————————————————

| Id  | Operation                   |  Name       | Rows  | Bytes | Cost  |

—————————————————————————

|   0 | SELECT STATEMENT            |             |       |       |       |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP         |       |       |       |

|*  2 |   INDEX RANGE SCAN          | EMP_ID1     |       |       |       |

—————————————————————————

Predicate Information (identified by operation id):

—————————————————

   2 – access(“EMP”.”EMPNO”=7777 AND “EMP”.”ENAME”=’RICH’ AND “EMP”.”DEP

              TNO”=30)

Note: rule based optimization

 

16 rows selected

 

 

 

 

使用了复合索引的全部列,所以走索引了,而且由于所有选择的列都包含在索引中,所以仅仅进行了索引范围扫描

select empno from emp where empno=7777 and ename=’RICH’ and deptno=30;

 

PLAN_TABLE_OUTPUT

——————————————————————————–

——————————————————————–

| Id  | Operation            |  Name       | Rows  | Bytes | Cost  |

——————————————————————–

|   0 | SELECT STATEMENT     |             |       |       |       |

|*  1 |  INDEX RANGE SCAN    | EMP_ID1     |       |       |       |

——————————————————————–

Predicate Information (identified by operation id):

—————————————————

   1 – access(“EMP”.”EMPNO”=7777 AND “EMP”.”ENAME”=’RICH’ AND “EM

              P”.”DEPTNO”=30)

Note: rule based optimization

 

15 rows selected

 

欢迎大家阅读《使用索引的误区之一:没有使用复合索引_sqlserver》,跪求各位点评,若觉得好的话请收藏本文,by



推荐阅读
  • 定制数据层关键字:数据层,访问,元数据,数据访问模型http://www.gaodaima.com/35448.html定制数据层_sqlserver ... [详细]
  • 关于SQLSERVER的全文目录跟全文索引的区别
    很久没有写随笔了,本来之前想写一篇关于SQLSERVER全文索引的随笔,可惜没有时间,一直拖到现在才有时间写,不好意思让各位久等了~先介绍一下SQLSERVER中的存储类对象,哈哈,先介绍一下概念嘛 ... [详细]
  • 6.1WMLScript规则这些标准函数库提供一个扩展WMLScript语言的机制,这些 ... [详细]
  • 转载:http:www.crazycoder.cnDataBaseIndex.html查询速度慢的原因很多,常见如下几种:1、没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设 ... [详细]
  • 本文探讨了在Qt框架下实现TCP多线程服务器端的方法,解决了一个常见的问题:服务器端仅能与最后一个连接的客户端通信。通过继承QThread类并利用socketDescriptor标识符,实现了多个客户端与服务器端的同时通信。 ... [详细]
  • 本文档提供了详细的MySQL安装步骤,包括解压安装文件、选择安装类型、配置MySQL服务以及设置管理员密码等关键环节,帮助用户顺利完成MySQL的安装。 ... [详细]
  • 本文介绍了JSP的基本概念、常用标签及其功能,并通过示例详细说明了如何在JSP页面中使用Java代码。 ... [详细]
  • 转自:http:blog.sina.com.cnsblog_67419c420100vmkt.html 1.为什么要使用blocks将一个blocks作为函数或者方法的参数传递,可 ... [详细]
  • 本文介绍如何在SQL Server中利用WITH子句和窗口函数ROW_NUMBER()来查询每个类型下的最新数据行。示例包括表结构、数据插入以及最终的查询语句。 ... [详细]
  • 本文详细介绍了在 Windows 7 上安装和配置 PHP 5.4 的 Memcached 分布式缓存系统的方法,旨在减少数据库的频繁访问,提高应用程序的响应速度。 ... [详细]
  • 数据库环境:SQLSERVER2005  有一个test表,其表结构及数据如下图1。其中,id是主键,mid是当前节点,pid是父节点。要求:查出每个节点的根节点,如图2所示。 ... [详细]
  • 1.3.4ProfilerSQLServerProfiler是一个图形化的管理工具用于监督记录和检查SQLServer数据库的使用情况对系统管理员来说它是一个监视用户活动的间谍1. ... [详细]
  • 在目标队列中对消息进行排队时出现异常。错误:15404,状态:19。CouldnotobtaininformationaboutWindowsNTgroupuserSERVER ... [详细]
  • SqlServer分区表概述(转载)
    什么是分区表一般情况下,我们建立数据库表时,表数据都存放在一个文件里。但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆分为多个小文件,还可以把这些小文件 ... [详细]
  • php5.3.x访问sqlserver2005
    由于项目需要,临时用php访问Sqlserver数据库,于是配置mssql扩展,但是无法访问,按照网上各种dll文件copy都不成功,最后终于发现是php版本问题,我的版本是php5.3 ... [详细]
author-avatar
情商是你弟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有