一、索引的概念
索引就是加快检索表中数据的方法。数据库的索引类似于书籍的索引。在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息。在数据库中,索引也允许数据库程序迅速地找到表中的数据,而不必扫描整个数据库。
二、索引的特点
1.索引可以加快数据库的检索速度
2.索引降低了数据库插入、修改、删除等维护任务的速度
3.索引创建在表上,不能创建在视图上
4.索引既可以直接创建,也可以间接创建
5.可以在优化隐藏中,使用索引
6.使用查询处理器执行SQL语句,在一个表上,一次只能使用一个索引
7.其他
三、索引的优点
1.创建唯一性索引,保证数据库表中每一行数据的唯一性
2.大大加快数据的检索速度,这也是创建索引的最主要的原因
3.加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。
4.在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。
5.通过使用索引,可以在查询的过程中使用优化隐藏器,提高系统的性能。
四、索引的缺点
1.创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加
2.索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大
3.当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度
五、索引分类
1.直接创建索引和间接创建索引
直接创建索引: CREATE INDEX mycolumn_index ON mytable (myclumn)
间接创建索引:定义主键约束或者唯一性键约束,可以间接创建索引
2.普通索引和唯一性索引
普通索引:CREATE INDEX mycolumn_index ON mytable (myclumn)
唯一性索引:保证在索引列中的全部数据是唯一的,对聚簇索引和非聚簇索引都可以使用
CREATE UNIQUE COUSTERED INDEX myclumn_cindex ON mytable(mycolumn)
3.单个索引和复合索引
单个索引:即非复合索引
复合索引:又叫组合索引,在索引建立语句中同时包含多个字段名,最多16个字段
CREATE INDEX name_index ON username(firstname,lastname)
4.聚簇索引和非聚簇索引(聚集索引,群集索引)
聚簇索引:物理索引,与基表的物理顺序相同,数据值的顺序总是按照顺序排列
CREATE CLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn) WITH
ALLOW_DUP_ROW(允许有重复记录的聚簇索引)
非聚簇索引:CREATE UNCLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn)
六、索引的使用
1.当字段数据更新频率较低,查询使用频率较高并且存在大量重复值是建议使用聚簇索引
2.经常同时存取多列,且每列都含有重复值可考虑建立组合索引
3.复合索引的前导列一定好控制好,否则无法起到索引的效果。如果查询时前导列不在查询条件中则该复合索引不会被使用。前导列一定是使用最频繁的列
4.多表操作在被实际执行前,查询优化器会根据连接条件,列出几组可能的连接方案并从中找出系统开销最小的最佳方案。连接条件要充份考虑带有索引的表、行数多的表;内外表的选择可由公式:外层表中的匹配行数*内层表中每一次查找的次数确定,乘积最小为最佳方案
5.where子句中对列的任何操作结果都是在sql运行时逐列计算得到的,因此它不得不进行表搜索,而没有使用该列上面的索引;如果这些结果在查询编译
时就能得到,那么就可以被sql优化器优化,使用索引,避免表搜索(例:select * from record where
substring(card_no,1,4)=’5378’
&& select * from record where card_no like ’5378%’)任何对列的操作都将导致表扫描,它包括数据库函数、计算表达式等等,查询时要尽可能将操作移至等号右边
6.where条件中的’in’在逻辑上相当于’or’,所以语法分析器会将in ('0','1')转化为column='0' or
column='1'来执行。我们期望它会根据每个or子句分别查找,再将结果相加,这样可以利用column上的索引;但实际上它却采用了"or策略
",即先取出满足每个or子句的行,存入临时数据库的工作表中,再建立唯一索引以去掉重复行,最后从这个临时表中计算结果。因此,实际过程没有利用
column上索引,并且完成时间还要受tempdb数据库性能的影响。in、or子句常会使用工作表,使索引失效;如果不产生大量重复值,可以考虑把子
句拆开;拆开的子句中应该包含索引
7.要善于使用存储过程,它使sql变得更加灵活和高效
分享到:
相关推荐
### 数据库索引详解 #### 一、索引的基本概念 索引是在数据库表中为了加快数据查询速度而创建的一种特殊的数据结构。当我们在数据库中进行数据查询时,如果没有索引,系统通常需要扫描整个表来查找所需的信息,这...
#### 一、索引的概念与分类 索引是数据库管理系统(DBMS)为了提高查询速度而采用的一种数据结构。它就像书籍的目录一样,帮助用户快速定位到所需的数据记录。 ##### 1.1 索引的分类 根据索引的数据存储方式不同...
### 关于索引概念、特点、优点、缺点、分类及使用的详细解读 #### 索引的概念 在数据库管理系统(DBMS)中,索引是一种数据结构,它可以帮助快速定位数据库表中的数据记录,从而提高数据检索的速度。索引类似于...
本文将深入探讨索引的概念、分类以及如何利用索引来优化查询性能。 1. 索引的作用与重要性 数据库索引如同书籍的目录,能够极大地加快数据查找速度,减少磁盘I/O操作,提高查询效率。在处理大量数据的大型表中,...
本文总结了基于Oracle数据库的索引优化方法,包括索引的概念、分类、设计和优化原则等。索引的概念是指为加速对表数据的访问而创建的数据段。索引类似于书的目录,包含表的列值和相应的ROW ID。ROW ID是 Oracle ...
### 数据库系统概念课后题Practice Exercises的答案解析 #### 第一部分:关系数据库 **1.1 数据库系统应用** 在数据库系统中,我们探讨的是如何有效地存储、管理和检索数据。这部分内容介绍了数据库系统的应用...
在本文中,我们将详细介绍数据库基础中的索引,包括索引的概念、分类、特点、优点、应用场景等。 索引的概念 ------------- 索引是数据库中的一种数据结构,它可以帮助快速地定位和检索数据。索引可以是某个列或多...
3. 数据库索引:索引是数据库管理系统中的一个重要概念,它加速了数据检索的速度。通过创建索引,数据库可以快速定位到所需数据,而无需全表扫描。常见的索引类型有B树、哈希索引、位图索引等,每种类型的索引在不同...
介绍数据库的基本概念、特点、作用和发展历程。 讲解数据库管理系统的功能和组成,以及数据库系统的三级模式结构。 数据模型 介绍数据模型的概念和分类,包括概念模型、逻辑模型和物理模型。 重点讲解关系模型的特点...
下面将详细介绍数据库的分类以及MySQL的相关知识。 首先,我们来探讨数据库的分类: 1. 关系型数据库(Relational Database):这是最常见的数据库类型,基于关系模型理论,以表格的形式存储数据,如MySQL、Oracle...
下面我们将详细解析数据库索引的概念、特点、分类以及设计要求。 1、索引的含义 索引是存储在磁盘空间中的数据库结构,主要包含数据表中创建索引的记录。索引的存在允许数据库在执行查询时能够快速定位到特定数据,...
1. **关系模型(Relational Model)**:这部分内容是数据库系统中最核心的部分之一,介绍了关系模型的基本概念、关系数据库的设计原则、以及如何使用关系模型对数据进行操作。本章节的习题将帮助学生掌握关系代数和...
根据提供的文件信息,可以看出这是一本关于数据库系统概念第五版的教材配套习题解答手册。以下将基于该手册的标题、描述以及部分内容,提取并解释关键知识点。 ### 一、数据库系统概念第五版 #### 1. 核心概念与...
### 数据库概念总结 #### 一、数据与数据库的基本概念 - **数据**: 描述事物的符号记录。例如,数字、字母、图像等都是数据的形式。 - **数据库**: 长期存储在计算机内的、有组织的、可共享的数据集合。数据库通过...
#### 一、Oracle分区索引概念及分类 在Oracle数据库中,分区索引是针对分区表的一种特殊索引类型,它可以显著提高对于大规模数据集的查询性能。根据索引是否与表的分区策略相匹配,分区索引可以分为两大类:本地...
综上所述,理解MySQL索引的不同分类和相关概念对于优化查询性能至关重要。正确地使用和设计索引可以显著提升数据库的读取速度,减少I/O操作,从而提高整体系统性能。在实际应用中,应根据业务需求和查询模式来合理...
8. **分布式数据库**:讲解分布式数据库的概念、分类,以及分布式数据库的管理和协调机制。 9. **NoSQL与大数据**:介绍非关系型数据库(如键值对、文档型、列族和图形数据库)的特点和应用场景,以及大数据处理...
- **主要内容**:介绍数据库的基本概念、历史背景以及其在现代信息系统中的重要性。 - **知识点**: - 数据库系统的定义与组成部分。 - 数据模型的概念及分类。 - 关系模型与非关系模型的区别。 - 数据管理技术...
1. 数据库基础知识:这部分内容通常会介绍数据库的概念、特点以及数据库管理系统的分类(如关系型数据库、对象关系型数据库、分布式数据库等)。还会包括数据库系统的组成,如硬件、软件、数据以及用户四个基本组成...
本章主要讲解了MySQL数据库中的索引概念、创建与删除方法,以及索引设计的原则。 1. **索引简介** - **含义与特点**:索引是数据库为了加速数据检索而创建的一种特殊数据结构,它存储了数据表中部分或全部列的值...