- 1、本文档共40页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据共享 数据独立 最小冗余 数据安全 数据完整 灵活性和可恢复性 章节目录 本章提要 第六章 视图和索引 6.2.3 索引的分类 2.主键索引 主键索引是在主键上建立的索引,具有惟一性,是惟一索引的特例。在一个表中,主键只能设置一个,可以是单独的字段也可以是字段组合。主键索引在一个表中只能建立一个,而惟一索引可以建立多个。 第六章 视图和索引 6.2.3 索引的分类 3.聚集索引 聚集索引建立后,表中记录的物理顺序与索引键值的逻辑顺序相同。在一个表中,数据只能按照一种物理顺序存储,所以一个表只能建立一个聚集索引。若想按照索引顺序显示记录,可将该索引设置为聚集索引。聚集索引不一定是惟一索引 。 第六章 视图和索引 6.2.3 索引的分类 4.非聚集索引 在非聚集索引中,数据行不一定按索引关键字的值排序。非聚集索引建立后,表中记录的物理顺序与索引键值的逻辑顺序可以不同。在一个表中,只允许建立一个聚集索引但允许建立多个非聚集索引。 6.2.4 索引的创建 1.使用SQL Server Management Studio管理器 以下用具体实例说明创建索引的步骤。 实例6-14 在“学生表”中按性别升序,再按学号降序, 建立聚集索引Index_1。 第六章 视图和索引 操作步骤: (1)单击 【开始】→ 【所有程序】→ 【Microsoft SQL Server 2005】→【SQL Server Management Studio】,打开【连接到服务器】对话框。 (2)单击【连接】钮,弹出【Microsoft SQL Server Management Studio】对话 框。 (3)在左窗格中展开数据库节点,再展开“学生成绩管理”数据库节点。将鼠标移到 该数据库的【dbo.学生表】对象,单击鼠标右键,打开“学生表”的快捷菜单 第六章 视图和索引 (4) 在弹出的菜单中单击【修改】,打开“学生表”结构 画面,在其中任意一个字段上单击鼠标右键,从弹 出的快捷菜单中单击【索引/键】 (5)单击【索引/键】后,打开【索引/键】对话框 (6)单击 钮,打开【索引列】对话框,先在列名位置选择“性别”,在排序顺序 位置选“升序”;再在列名位置选“学号”,在排序顺序位置选“降序”。 (7)单击【确定】钮,返回【索引/键】对话框,在标识名称位置给索引文件命名为 “Index_1”,在“创建为聚集的”的位置选择“是”。 (8)单击【关闭】钮,完成索引的创建。学生表中记录的排列顺序 2.使用代码 使用T-SQL代码建立索引的语法格式为: create [unique] [clustered] [nonclustered] index 索引名 on 表名(列名1,列名2……) 语法注释: [unique] 表示创建的索引是惟一索引 [clustered] 表示创建的是簇集索引 [nonclustered] 表示创建的是非簇集索引 第六章 视图和索引 实例6-15 在“学生表”中按姓名字段创建惟一的簇集索引 “Index_2”。 操作步骤: (1)单击【开始】→【所有程序】→【Microsoft SQL Server 2005】 → 【SQL Server Management Studio】,打开 【连接到服务器】对话框, 单击 【连接】钮,弹出【Microsoft SQL Server Mana -gement Studio】管理器窗口。 第六章 视图和索引 (2)单击常用工具栏中的 钮,则建立了一个数据库引擎查询文档,文档名 默认为SQLQuery1.sql。 (3)在SQLQuery1.sql文档界面输入代码: drop index 学生表.index_1 create unique clustered index index_2 on 学生表(姓名) go select * from 学生表 (4)单击工具栏上的 按钮,或按F5键 必须将“Index_1”删除,才可建立“Inedx_2”,因
文档评论(0)