分开SQL Server的主键和索引,使用聚类索引提高性能!

一直以来,对数据库只是会用,很少系统的学习过,很多概念知道但是不是很熟悉。
   索引--可以加快搜索速度。这是我脑子里面的概念,可是SQL Server中索引有聚类索引(CLUSTERED)和非聚类索引。我数据表一般有ID字段,我就自然把它设置成了主键;而SQL Server会将主键设置为聚类索引,很多情况下,这是一种性能损失!!
1. SQL Server联机丛书中的介绍

根据数据库的功能,可在数据库设计器中创建三种类型的索引 — 唯一索引、主键索引和聚集索引。

提示   尽管唯一索引有助于找到信息,但为了获得最佳性能,建议使用主键约束或唯一约束。有关这些约束的更多信息,请参见主键约束和唯一约束。

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

主键索引
数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。该列称为表的主键。

在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。

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

如果不是聚集索引,表中各行的物理顺序与键值的逻辑顺序不匹配。聚集索引比非聚集索引有更快的数据访问速度。

2. 聚集索引和非聚集索引




可考虑将聚集索引用于:

包含数量有限的唯一值的列,如 state 列只包含 50 个唯一的州代码。

使用下列运算符返回一个范围值的查询:BETWEEN、>、>=、< 和 <=。

返回结果集查询。
数据表中的记录按照聚集索引排列的,所以将大规模查询的字段定义成聚类索引,能大大的提高性能!

3. 实际例子

如表结构TB_NEWS:四个字段

ID  uniqueidentifier(16)

NewsTitle varchar(200)

NewContent Text(16)

InsertDate smallDateTime(8)

-----------------------------------------------------------------------------

按照习惯,将表的字段设置后,顺手将主键设置为ID,这样做的后果就是:数据库自动为ID建立聚类索引。对于网站新闻,最主要的查询操作,查询按照时间段。典型的查询是

select ID, NewsTitle, NewContend, InsertDate

from TB_NEWS

where InsertDate between @DataTime1 and @DataTime2

在一个有大于105条数据的表中查询效率明显不高。数据表中记录存放竟然按照uniqueidentifier这样无序的东西存放,简直是资源浪费啊,查询将遍历所有记录,后果可想而知。用InsertDate 作聚类索引,查询速度绝对可以,InsertDate字段不会被修改,所以受影响的仅仅是插入数据操作。

单条的查询可以这样写:和只用ID的查询,不知道哪个更快:)可以测试一下,呵呵

select ID, NewsTitle, NewContend, InsertDate

from TB_NEWS

where InsertDate = @DataTime and ID= @ID

我觉得方法应该是:

1.设计表

2. 输入字段类型

3. 选择合适字段建立 聚类索引

4. 使用ID建立主键

你可能感兴趣的:(数据结构,sql,SQL Server)