码迷,mamicode.com
首页 > 数据库 > 详细

Sqlserver 索引

时间:2015-08-08 12:03:01      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:

通过了解相关知识,大体明白了sqlserver索引的基础知识。

索引是为了优化查询效率,过多的重复索引将影响数据的增删改操作。所以使用的时候应具实际情况进行添加。

索引类型分为:唯一索引、主键索引、聚集索引和非聚集索引。

唯一索引:唯一索引不允许两行具有相同的索引值。 

主键索引:为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的,并且不能为空

聚集索引:表中的各行物理顺序与键值的逻辑(索引)顺序相同,每个表只能有一个。

非聚集索引:非聚集索引指定表的逻辑顺序。数据存储在一个位置,索引存储在另一个位置,索引中包含指向数据存储位置的指针。可以有多个,小于249个。

 

SQL Server中,一个表只能创建1个聚集索引,多个非聚集索引。设置某列为主键,该列就默认为聚集索引。

 

如何创建索引

使用T-SQL语句创建索引的语法:

CREATE [UNIQUE] [CLUSTERED|NONCLUSTERED] 

    INDEX   index_name

     ON table_name (column_name…)

      [WITH FILLFACTOR=x]

        UNIQUE表示唯一索引,可选

        CLUSTERED、NONCLUSTERED表示聚集索引还是非聚集索引,可选

        FILLFACTOR表示填充因子,指定一个0到100之间的值,该值指示索引页填满的空间所占的百分比

 

虽然我们可以指定SQL Server按哪个索引进行数据查询,但一般不需要我们人工指定。SQL Server将会根据我们创建的索引,自动优化查询 。

 

索引的优缺点

•          优点

–         加快访问速度

–         加强行的唯一性

•          缺点

–         带索引的表在数据库中需要更多的存储空间

–         操纵数据的命令需要更长的处理时间,因为它们需要对索引进行更新

 

创建索引的指导原则

•          请按照下列标准选择建立索引的列。

–         该列用于频繁搜索

–         该列用于对数据进行排序

•          请不要使用下面的列创建索引:

–         列中仅包含几个不同的值。

–         表中仅包含几行。为小型表创建索引可能不太划算,因为SQL Server在索引中搜索数据所花的时间比在表中逐行搜索所花的时间更长

 

参考文章:http://www.cnblogs.com/fish-li/archive/2011/06/06/2073626.html

     http://blog.csdn.net/lenotang/article/details/3329501

 

Sqlserver 索引

标签:

原文地址:http://www.cnblogs.com/willperfect/p/4712789.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!