SQL Server 索引介绍

一,索引的概述

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语句创建索引:

语法:

代码如下:
(cloumn[asc|desc][,……n]) [include (column_name[,……n])] [with([,……n])] [onfilegroup_name]

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

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

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

代码如下:


2,查看索引:(1),使用SQL ServerManagement Studio查看索引信息

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

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


3,修改索引:

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

(2),使用Alter Index语句修改索引

在这里为大家举一个例子:

在course数据表中,修改所有的索引,并指定选项

代码如下:


4,删除索引:

(1),使用SQL Server Management Studio 删除索引

(2),使用Drop index语句删除索引

例如:在course表中,删除zindex索引

代码如下:


三,索引的分析和维护:

分析:1,使用showplan 语句

语法:set showplan_all{on|off},set showplan_next{on|off}

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

代码如下:


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语句,意思是重建数据库中表的一个或多个索引。

语法:

代码如下:

说明: database.owner.table_name,重新建立索引的表名

index_name,是要重建的索引名

fillfactor,要创建索引时每个索引页上要用于存储数据的空间百分比。

with no_infomsgs,禁止显示所有信息性消息

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

语法:

代码如下:


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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sqlalche...
今天小编给大家分享一下sqlServer实现分页查询的方式有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家
这篇文章主要介绍“sqlmap之osshell怎么使用”,在日常操作中,相信很多人在sqlmap之osshell怎么使用问题上存在疑惑,小编查阅了各式资料,整理出
本篇内容介绍了“SQL注入的知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧...
1. mssql权限sa权限:数据库操作,文件管理,命令执行,注册表读取等system。是mssql的最高权限db权限:文件管理,数据库操作等 users-administratorspublic权限:数据库操作 guest-users2、sql server注入执行命令查
sql执行计划如何查看?在SPL庞大的数据中我们不知道如何查看实际数据库中发生了什么事情,有必要定期进行查询优化和索引否则会影响我们后期的SQL的查询速度。那么针对这样的问题我们必须要知道SQL执行的计划,在本文中winwin7小编给大家分享下SQL执
SQL Server 是Microsoft 公司推出的关系型数据库管理系统。具有使用方便可伸缩性好与相关软件集成程度高等优点应用非常广泛。不过在使用中,我们会遇到非常多的错误,面对这么庞大的数据库环境,当然会有精确的错误代码的对照季,下面小编分享的
SQL Server本地账户无法登陆出现错误提示:error:40-Could not open a connenction to SQL Server的问题很常见,对于初学者来说可能不知道如何解决,一起来看看下面的解决方案。解决步骤如下:1、这种情况需要开启 SQL Server service
微软推出的SQL2008是一款非常好用的数据库软件,它稳定、功能强大,为众多企业提供了最佳的数据库解决方案,那么我们如何在Windows中安装它呢,一些朋友对SQL Server 2008的安装过程还不是很熟悉,下面就一起来看看SQL Server 2008详细安装图解...
本页概要如果您使用的是 SQL Server 2005备份和还原Sp_detach_db 和 Sp_attach_db 存储过程关于排序规则的说明导入和导出数据(在 SQL Server 数据库之间复
DBCC CHECKIDENT 检查指定表的当前标识值,如有必要,还对标识值进行更正。 语法 DBCC CHECKIDENT ( 'table_name' [ , { NORESEED
这里对 SQL Server 字符串函数进行分门别类地列出,便于查阅和记忆,相信大家都在其它方面有高深的编程基础,从字面上来说大家都知道这些函数的意义,就不对这些函数作过多的解释了,主要谈些经验,具体
查询及删除重复记录的方法 1、查找表(people)中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select*frompeoplewherepeopleIdin(selectpe
微软发SQL Server 2008第二个CTP预览版from: http://news.csdn.net/n/20070807/107158.html8月7日消息,微软公司本周发布了SQL Serv
症状当您将数据库备份恢复到另一台服务器时,可能会遇到孤立用户的问题。SQL Server 联机丛书中的孤立用户疑难解答主题中没有讲述解决此问题的具体步骤。本文介绍了如何解决孤立用户问题。更多信息虽然术
当登录SQL Server 2005时可能碰到错误: 'No Process is on the Other End of the Pipe'。解决方法:(1)Open up SQL
概要本文描述如何映射标准登录和集成登录来解决在运行 SQL Server 的服务器之间移动数据库时的权限问题。更多信息当您将数据库从一个运行 SQL Server 的服务器移到另一个运行 SQL Se
----------------------------------------问题:该用户与可信的SQL SERVER 连接无关联使用sa用户或自建用户使用“SQL SERVER 身份认证”连接数据
更新日期: 2007 年 5 月 20 日 使用下表可以确定各种版本的 Microsoft SQL Server 2005 支持哪些功能。有关 SQL Server 2005 Enterprise E
当从Excel导入数据到Sql Sever中,可能会出现以下问题:
对于指定的缓冲区大小而言,源列的数据太大