本文整理自网络,侵删。
目录
- 一、索引的介绍
- 什么是索引?
- 1、聚集索引和非聚集索引
- 2、索引的利弊
- 3、索引的存储机制
- 二、设置索引的权衡
- 1、什么情况下设置索引
- 2、什么情况下不要设置索引
- 三、聚集索引
- 1、使用SSMS创建聚集索引
- 2、使用T-SQL创建聚集索引
- 四、非聚集索引
- 1、SSMS创建方法同上,T-SQL创建方法如下:
- 2、添加索引选项
- 五、示例
- 六、管理索引
一、索引的介绍
什么是索引?
索引是一种磁盘上的数据结构,建立在表或视图的基础上。使用索引可以使数据的获取更快更高校,也会影响其他的一些性能,如插入或更新等。
索引主要分为两种类型:
1、聚集索引和非聚集索引
字典的目录就是一个索引,按照拼音查询想要的字就是聚集索引(物理连续,页码与目录一一对应),偏旁部首就是一个非聚集索引(逻辑连续,页码与目录不连续)。
聚集索引存储记录是物理上连续存在的,而非聚集索引是逻辑上的连续,物理存储并不连续。
聚集索引一个表中只能有一个,而非聚集索引一个表中可以有多个。
2、索引的利弊
使用索引是为了避免全表扫描,因为全表扫描是从磁盘上读取表的每一个数据页,如果有索引指向数据值,则只需要读少次数的磁盘就可以。
带索引的表在数据库中占用更多的空间,同样增、删、改数据的命令所需时间会更长。
3、索引的存储机制
书中的目录是一个字词以及所在的页码列表,数据库中的索引是表中的值以及各值存储位置的列表。
聚集索引是在数据库中新开辟一个物理空间,用来存放他排列的值,当有新数据插入时,他会重新排列整个物理存储空间。
非聚集索引只包含原表中的非聚集索引的列和指向实际物理表的一个指针。
数据表的基本结构
当一个新的数据表创建时,系统将在磁盘中分配一段以8k为单位的连续空间。当一个8k用完的时候,数据库指针会自动分配一个8k的空间,每个8k的空间称为一个数据页,并分配从0-7的页号,每个文件的第0页记录引导信息叫页头,每8个数据页由64k组成形成扩展区。全部数据页的组合形成堆。
SQL Server规定行不能跨越数据页,所以每行记录的最大数量只能是8k,这就是为什么char和varchar这两种字符类型容量要限制在8k以内的原因,存储超过8k的数据应使用text类型,其实text类型的字段值不能直接录入和保存,它是存储一个指针,指向由若干个8k的数据页所组成的扩展区,真正的数据其实放在这些数据页中。
二、设置索引的权衡
1、什么情况下设置索引
- 定义主键的数据列(sql server默认会给主键一个聚集索引)。
- 定义有外键的数据列
- 对于经常查询的数据列
- 对于需要在指定范围内频繁查询的数据列
- 经常在where子句中出现的数据列
- 经常出现在关键字 order by、group by、distinct后面的字段。
2、什么情况下不要设置索引
- 查询中很少涉及的列,重复值比较多的列。
- text、image、bit数据类型的列
- 经常存取的列
- 经常更新操作的表,索引一般不要超过3个、最多不要5个。虽说提高了访问速度,但会影响更新操作。
三、聚集索引
1、使用SSMS创建聚集索引
展开要创建索引的表->右击索引->选择新建索引->聚集索引->新建索引点添加->选择列->选择升序或降序->输入名字->确定。
相关阅读 >>
更多相关阅读请进入《sql》频道 >>
数据库系统概念 第6版
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » SQL Server中索引的用法详解
相关推荐
评论
管理员已关闭评论功能...