有了 primary key , 还需要复合索引吗 ?

zjlgigi 2009-08-17 06:04:53
Hi 高手,

小弟有一个表,比较简单,有 10 列。。其中有一列是 primary key , 有一列是条件列 ,

如果我把 primary key + 条件列 弄成一个索引 , 会对系统带来性能上的提升吗 ?


谢谢 !

外星人
...全文
419 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
devilidea 2009-08-17
  • 打赏
  • 举报
回复
o
feixianxxx 2009-08-17
  • 打赏
  • 举报
回复
--如果你表里没有聚集索引
--当你建立主键时候 系统强制给主键了一个聚集索引
xiequan2 2009-08-17
  • 打赏
  • 举报
回复
[Quote=引用楼主 zjlgigi 的回复:]
Hi 高手,

小弟有一个表,比较简单,有 10 列。。其中有一列是 primary key , 有一列是条件列 ,

如果我把 primary key + 条件列 弄成一个索引 , 会对系统带来性能上的提升吗 ?


谢谢 !

外星人
[/Quote]

符合索引是否提升效率与你写法有关,你直接在条件列加索引就可以了
黄_瓜 2009-08-17
  • 打赏
  • 举报
回复
索引--可以加快搜索速度。这是我脑子里面的概念,可是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建立主键
SQL77 2009-08-17
  • 打赏
  • 举报
回复
不过觉得你直接加在条件上就好了
SQL77 2009-08-17
  • 打赏
  • 举报
回复
会吧

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧