数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力

详细出处参考:http://www.jb51.net/article/30950.htm

一、索引的概述

1.概念: 数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力.

2.优缺点:

2.1 优点: 1.大大加快搜索数据的速度,这是引入索引的主要原因.

2.创建唯一性索引,保证数据库表中每一行数据的唯一性.

3.加速表与表之间的连接,特别是在实现数据的参考完整性方面特别有意义.

4.在使用分组和排序子句进行数据检索时,同样可以减少其使用时间.

2.2 缺点: 1.索引需要占用物理空间,聚集索引占的空间更大.

2.创建索引和维护索引需要耗费时间,这种时间会随着数据量的增加而增加.

3.当向一个包含索引的列的数据表中添加或者修改记录时,SQL server 会修改和维护相应的索引,这样增加系统的额外开销,降低处理速度。

3.索引的分类:

1.按存储结构可分为:

a.聚集索引:指物理存储顺序与索引顺序完全相同,它由上下两层组成,上层为索引页,下层为数据页,只有一种排序方式,因此每个表中只能创建一个聚集索引。

b.非聚集索引:指存储的数据顺序一般和表的物理数据的存储结构不同。

通过下表我们可以分析出:(其中在学号上建立非聚集索引)

2. 根据索引键值是否唯一,可以判定是否为唯一索引;基于多个字段的组合创建索引的为组合索引。

二、索引的操作:

1.创建:

(1)原则:

a.只有表的所有者可以在同一个表中创建索引;

b.每个表中只可以创建一个聚集索引;

c.每个表中最多可以创建249个非聚集索引;

d.在经常查询的字段上建立索引;

e.定义text,image和bit数据类型的列上不能创建索引;

f.在外键列上可以创建索引,主键上一定要有索引;

g.在那些重复值比较多的,查询较少的列上不要建立索引。

(2)方法:

a.使用SQL server Management Studio创建索引。

b.使用T-SQL语句中的create Index语句创建索引

c.使用Create table或者alter Table语句为表列定义主键约束或者唯一性约束时,会自动创建主键索引和惟一索引。

这里说说T-sql语句创建索引:

语法:

代码如下:

create relational index 

create[unique][clustered|nonclustered] index index_name on<object>(cloumn[asc|desc][,……n]) [include (column_name[,……n])] [with(<relational_index_option>[,……n])] [onfilegroup_name]

说明:

1.include (column_name[,……n])指定要添加到非聚集索引的叶级别的非键列。

2.on filegroup_name,为指定文件组创建指定索引。

例如:在course表中,对“课程代号”列创建聚集索引zindex.

代码如下:

use db_student create clustered index zindex on course(课程代号)

2.查看索引:

(1).使用SQL ServerManagement Studio查看索引信息

(2).使用系统存储过程查询索引信息,用SP_helpindex可以返回表中的所有索引信息

例如:查看course表的索引信息

use db_student exec sp_helpindex course[/code]

3.修改索引:

(1). 在SQL Server Management Studio 中修改索引

(2). 使用Alter Index语句修改索引  在这里为大家举一个例子:  在course数据表中,修改所有的索引,并指定选项

代码如下:

use db_student alter index all on course rebuild with (fillfactor=80,sort_in_tempdb=on,statistics_norecompute=on)

4.删除索引:

(1).使用SQL Server Management Studio 删除索引
   (2).使用Drop index语句删除索引  例如:在course表中,删除zindex索引

代码如下:

use db_student drop index course.zindex

三、索引的分析和维护:

分析:

1.使用showplan 语句

语法:

set showplan_all{on|off},set showplan_next{on|off}

例子:显示表course的课程代号,课程类型,课程内容,并显示查询过程

代码如下:

use db_student set showplan_all on select 课程代号,课程类型 课程内容 from course where 课程内容='loving'

2.使用statistics io语句

语法:statistics io{on|off} on和off分别为显示和不显示,使用方法和上一样。

维护:

1.使用dbcc showcontig语句,显示指定表的数据和索引的碎片信息。当对表中进行大量修改或添加数据后,应该执行此语句查看有无碎片。

语法:dbcc showcontig[{table_name|table_id|view_name|view_id},index_name|index_id] with fast

2.使用dbcc dbreindex语句,意思是重建数据库中表的一个或多个索引。

语法:

代码如下:

dbcc dbreindex (['database.owner.table_name'[,index_name[,fillfactor]]]) [withno_infomsgs]

说明: database.owner.table_name,重新建立索引的表名  index_name,是要重建的索引名 fillfactor,要创建索引时每个索引页上要用于存储数据的空间百分比。 with no_infomsgs,禁止显示所有信息性消息

3.使用dbcc indexdefrag,整理指定的表或视图的聚集索引和辅助索引碎片。

语法:

代码如下:

dbcc indexdefrag ({database_name|database_id|0},{table_name|table_id|'view_name'|view_id},{index_name|index_id}) with no_infomsgs 

总结,只有我们对索引有了充分了熟悉;我们掌握了索引的增删改查四项基本操作,学会利用SQL Server ManagerSdudio去实现这些功能,和学会利用T-SQL语句去实现(自我感觉利用SQL Server Manager Sdudio 简单一些);当然还要懂得学会分析和维护索引,这样才会更好的让它为咱们服务!

SQL Server 索引介绍的更多相关文章

  1. 【译】索引进阶(一):SQL SERVER索引介绍

      [译注:此文为翻译,由于本人水平所限,疏漏在所难免,欢迎探讨指正]  原文链接:http://www.sqlservercentral.com/articles/Stairway+Series/7 ...

  2. SQL Server索引进阶:第十级,索引内部结构

    原文地址: Stairway to SQL Server Indexes: Level 10,Index Internal Structure 本文是SQL Server索引进阶系列(Stairway ...

  3. SQL Server索引进阶:第八级,唯一索引

    原文地址: Stairway to SQL Server Indexes: Level 8,Unique Indexes 本文是SQL Server索引进阶系列(Stairway to SQL Ser ...

  4. SQL Server索引进阶:第六级,标签

    原文地址: Stairway to SQL Server Indexes: Level 6,Bookmarks 本文是SQL Server索引进阶系列(Stairway to SQL Server I ...

  5. SQL Server索引进阶:第五级,包含列

    原文地址: Stairway to SQL Server Indexes: Level 5, Included Columns 本文是SQL Server索引进阶系列(Stairway to SQL ...

  6. SQL Server索引进阶:第四级,页和区

    原文地址: Stairway to SQL Server Indexes: Level 4, Pages and Extents 本文是SQL Server索引进阶系列(Stairway to SQL ...

  7. SQL Server索引进阶:第三级,聚集索引

    原文地址: Stairway to SQL Server Indexes: Level 3, Clustered Indexes 本文是SQL Server索引进阶系列(Stairway to SQL ...

  8. SQL Server索引进阶:第二级,深入非聚集索引

    原文地址: Stairway to SQL Server Indexes: Level 2, Deeper into Nonclustered Indexes 本文是SQL Server索引进阶系列( ...

  9. SQL Server索引进阶:第一级,索引简介

    这个并不是我翻译的,全文共有15篇,但我发现好多网站已经不全,所以自己整理. 原文地址: Stairway to SQL Server Indexes: Level 1, Introduction t ...

随机推荐

  1. Object Pascal 方法与技巧

    4 方法与技巧 4.1 设置代码模板 代码模板是Delphi 的代码感知特性的一种,通过它可以快速.高效和正确地输入代码.代码模板将一些常用的语句块保存在模板中,然后程序员只要在代码编辑器中按下“Ct ...

  2. 【linux】设置 tomcat 开机启动

    方法一: linux 下tomcat开机自启动修改Tomcat/bin/startup.sh 为: export JAVA_HOME=/usr/java/j2sdk1.4.2_08 export CL ...

  3. Http报头Accept与Content-Type的区别

    Http报头Accept与Content-Type的区别 1.Accept属于请求头, Content-Type属于实体头. Http报头分为通用报头,请求报头,响应报头和实体报头. 请求方的http ...

  4. 转!! Java中ThreadLocal的设计与使用

    首先,ThreadLocal 不是用来解决共享对象的多线程访问问题的,一般情况下,通过ThreadLocal.set() 到线程中的对象是该线程自己使用的对象,其他线程是不需要访问的,也访问不到的.各 ...

  5. WebBrowser的内存释放

    WebBrowser窗口自动滚动: this.webBrowser.Document.Window.ScrollTo(0, webBrowser1.Document.Body.ScrollRectan ...

  6. virtualbox虚拟机上安装centOS的网络配置(安装centos时选择桥接网络)

    最近接触hadoop,需要在在Linux上面开发,所以我装了一个virtualbox虚拟机,在该虚拟机上面安装了一个centOS系统.linux系统是装好了,但是网络配置却另人头疼.我主要是想让宿主机 ...

  7. 详解DHV:怎么具体展示高价值

    我的理解里面:高价值分两个部分,一个是静态的,一个是动态的. 我把静态的称为硬性指标,动态的称为软性指标. 下面我给大家仔细解释一下两个指标的具体展示. ----------------------- ...

  8. linux笔记:linux常用命令-网络命令

    网络命令:ping(测试网络连通性) 网络命令:ifconfig(查看和设置网卡信息) 注意:在查看网卡信息时,直接输入ifconfig命令即可. 网络命令:last(列出目前和过去登入系统的用户信息 ...

  9. robot API笔记4

    robot.htmldata包 包编写HTML格式的输出文件. 这个包被认为是稳定的但不是公共API的一部分. robot.htmldata.htmlfilewriter module classro ...

  10. Shell基础:Shell和Mysql交互

    通过命令行和Mysql交互 [root]#mysql -uroot -p123 -e "show databases"   -e: execute: 执行数据库命令 通过脚本和数据 ...