网站大量收购独家精品文档,联系QQ:2885784924

SQL Server2000数据库及应用 李伟红 第5章 索引的创建与维护新.ppt

SQL Server2000数据库及应用 李伟红 第5章 索引的创建与维护新.ppt

  1. 1、本文档共48页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第5章 索引的创建与维护 北华航天工业学院 李伟红 本章学习目标 了解索引的概念及作用; 掌握索引的分类; 掌握创建索引的方法; 掌握查看和修改索引的方法; 掌握删除索引的方法。 5.1 索引概述 5.1.1 索引简介 在数据库中,如果想在某个数据表中快速查找满足条件的记录,可以创建索引。 使用索引有许多好处。例如,通过创建惟一索引,可以保证数据记录的惟一性;使用索引可以大大加快数据检索速度;使用索引还可以加速表与表之间的连接。 5.1.1 索引简介 建立索引的一般原则是: 对经常用来检索的字段建立索引。 对数据表中的主键建立索引。 对数据表中的外键建立索引。 对经常用于连接的字段建立索引。 5.1.2 索引的分类 1.聚集索引和非聚集索引 在SQL Server 2000数据库中,按照存储结构的不同,可以将索引分为两类,即聚集索引和非聚集索引。 1.聚集索引和非聚集索引 聚集索引对表在物理数据页中的数据按列进行排序,然后再重新存储到磁盘上。一个表只能有一个聚集索引。 1.聚集索引和非聚集索引 创建聚集索引时应该考虑以下几个因素: 每个表只能有一个聚集索引。 创建任何非聚集索引之前首先要创建聚集索引。 要保证有足够的空间创建聚集索引。 1.聚集索引和非聚集索引 非聚集索引具有完全独立于数据行的结构,使用非聚集索引不会影响数据表中记录的实际存储顺序,而且它比聚集索引需要较少的存储空间,但检索效率比聚集索引低。当用户需要建立多个索引时,就需要使用非聚集索引了。 1.聚集索引和非聚集索引 在下列情况下,可以考虑使用非聚集索引: 含有大量惟一值的字段。 返回很小的或者单行结果集的检索。 使用ORDER BY子句的查询。 2.复合索引 如果需要对多个字段的组合创建索引,则可以建立复合索引。在一个复合索引中最多可以有16个字段组合,并且复合索引中的所有字段必须在同一个表中。 3.惟一索引 如果要求索引中的字段值不能重复,可以建立惟一索引。 对于已建立了惟一索引的数据表,当向数据表中添加记录或修改原有记录时,系统将检查添加的记录或修改后的记录是否满足惟一性的要求,如果不满足将不会被接受。 5.2 创建索引 索引可以由系统自动创建,也可以由用户手工创建。手工创建索引常用以下几种方法。 (1)利用企业管理器直接创建索引。 (2)利用Transact-SQL语句中的CREATE INDEX命令创建索引。 (3)利用企业管理器中的索引向导创建索引。 5.2.1 系统自动创建索引 系统在创建表中的其他对象时可以附带地创建新索引。例如,新建表时,可以创建主键或者惟一性约束,同时就创建了索引。 5.2.1 系统自动创建索引 例5-1 在BOOKS数据库中创建一个新的数据表“图书基本信息表5”,并将其中的“图书编码”字段设置为主键。 5.2.2 使用企业管理器创建索引 (1)在企业管理器中,展开指定的服务器和数据库,选择要创建索引的表,并右击其中的某一个数据表,从弹出的快捷菜单中依次选择“所有任务”→“管理索引”命令。 5.2.3 使用Transact-SQL语句创建索引 利用Transact-SQL语句中的CREATE INDEX命令可以创建索引,CREATE INDEX命令既可以创建一个可改变表的物理顺序的聚集索引,也可以创建提高查询性能的非聚集索引。 5.2.3 使用Transact-SQL语句创建索引 其语法形式如下: CREATE [ UNIQUE ] [ CLUSTERED | NONCLUSTERED ] INDEX index_name ON { table | view } ( column [ ASC | DESC ] [ ,...n ] ) 5.2.3 使用Transact-SQL语句创建索引 [WITH [PAD_INDEX] [[,]FILLFACTOR=fillfactor] [[,]IGNORE_DUP_KEY] [[,]DROP_EXISTING] [[,]STATISTICS_NORECOMPUTE] [[,]SORT_IN_TEMPDB]    ] [ ON filegroup ] 5.2.3 使用Transact-SQL语句创建索引 其中各参数的说明如下: UNIQUE:用于指定为表或视图创建惟一索引,即不允许存在索引值相同的两个数据行。在字段中包含重复值时,不能创建惟一索引。如要使用此选项,则应确定索引所包含的字段均不包含NULL值,否则在使用时会经常出错。 5.2.3 使用Transact-SQL语句创建索引 CLUSTERED:用于指定创建的索引为聚集索引。如果此选项为默认,则创建的索引为非聚集索引。 NONCL

文档评论(0)

精品课件 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档