蝈蝈俊.net

-- 用随笔来记录自己的技术感触
随笔 - 674, 评论 - 4465, 引用 - 276

导航

关于

记录自己的技术心得

标签

每月存档

最新留言

  • Gzcwpcwk
    i'm fine good work <a href=" http://www.wikio.com/user/nihaaryhya/bio "&...
    by Gzcwpcwk(匿名) on 2010/3/22 16:47:06
  • Kyylbbti
    i'm fine good work <a href=" http://www.wikio.com/user/nihaaryhya/bio "&...
    by Kyylbbti(匿名) on 2010/3/22 16:47:04
  • Nmwekkuj
    Gloomy tales <a href=" http://www.wikio.com/user/ytelobycodogu/bio "&gt...
    by Nmwekkuj(匿名) on 2010/3/22 16:47:03
  • Qvzrwujy
    perfect design thanks <a href=" http://www.wikio.com/user/opygatuyfu/bio "&...
    by Qvzrwujy(匿名) on 2010/3/22 14:39:39
  • Mqddegva
    Best Site Good Work <a href=" http://www.wikio.com/user/opygatuyfu/bio "&am...
    by Mqddegva(匿名) on 2010/3/22 14:39:37
  • Ngbdxzyy
    very best job <a href=" http://www.wikio.com/user/erigasymiqihe/bio "&g...
    by Ngbdxzyy(匿名) on 2010/3/22 14:39:36
  • Ettqhzac
    this is be cool 8) <a href=" http://www.wikio.com/user/opygatuyfu/bio "&...
    by Ettqhzac(匿名) on 2010/3/22 13:19:15
  • Pjasuhde
    Gloomy tales <a href=" http://www.wikio.com/user/utouanuni/bio ">lol...
    by Pjasuhde(匿名) on 2010/3/22 13:19:13
  • Ldzhpjhw
    Best Site good looking <a href=" http://www.wikio.com/user/omanylaan/bio "&...
    by Ldzhpjhw(匿名) on 2010/3/22 13:19:11
  • Cxmwoinm
    Very interesting tale <a href=" http://www.wikio.com/user/oposulijo/bio "&a...
    by Cxmwoinm(匿名) on 2010/3/22 12:32:37

广告

 

有些人可能对主键和聚集索引有所混淆,其实这两个是不同的概念,下面是一个简单的描述。不想看绕口文字者,直接看两者的对比表。尤其是最后一项的比较。

主键(PRIMARY KEY )

来自MSDN的描述:

表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。

一个表只能有一个 PRIMARY KEY 约束,并且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束可保证数据的唯一性,因此经常对标识列定义这种约束。

如果为表指定了 PRIMARY KEY 约束,则 SQL Server 2005 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。

创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 PRIMARY KEY 约束。

 

聚集索引

聚集索引基于数据行的键值在表内排序和存储这些数据行。每个表只能有一个聚集索引,因为数据行本身只能按一个顺序存储。

每个表几乎都对列定义聚集索引来实现下列功能:

  • 可用于经常使用的查询。
  • 提供高度唯一性。

两者的比较

下面是一个简单的比较表

  主键 聚集索引
用途 强制表的实体完整性 对数据行的排序,方便查询用
一个表多少个 一个表最多一个主键 一个表最多一个聚集索引
是否允许多个字段来定义 一个主键可以多个字段来定义 一个索引可以多个字段来定义
     
是否允许 null 数据行出现 如果要创建的数据列中数据存在null,无法建立主键。
创建表时指定的 PRIMARY KEY 约束列隐式转换为 NOT NULL。
没有限制建立聚集索引的列一定必须 not null .
也就是可以列的数据是 null
参看最后一项比较
是否要求数据必须唯一 要求数据必须唯一 数据即可以唯一,也可以不唯一。看你定义这个索引的 UNIQUE 设置。
(这一点需要看后面的一个比较,虽然你的数据列可能不唯一,但是系统会替你产生一个你看不到的唯一列)
     
创建的逻辑 数据库在创建主键同时,会自动建立一个唯一索引。
如果这个表之前没有聚集索引,同时建立主键时候没有强制指定使用非聚集索引,则建立主键时候,同时建立一个唯一的聚集索引
如果未使用 UNIQUE 属性创建聚集索引,数据库引擎 将向表自动添加一个四字节 uniqueifier 列。
必要时,数据库引擎 将向行自动添加一个 uniqueifier 值,使每个键唯一。此列和列值供内部使用,用户不能查看或访问。

参考:

下面这个帖子中大力的回复:
http://topic.csdn.net/t/20021212/16/1255429.html

打印 | 张贴于 2008-01-04 14:07:00 | Tag:数据库开发管理心得

留言反馈

#SQL Server 索引基础知识(6)----索引的代价,使用场景 编辑
前几天给同事培训了聚集索引,非聚集索引的知识后,在一个同事新作的项目中,竟然出现了滥用聚集索引的问题。看来没有培训最最基础的索引的意义,代价,使用场景,是一个非常大的失误。这篇博客就是从这个角度来罗列索引的基础知识
2008-01-19 02:07:00 | [匿名:ASP.NET Chinese Blogs]
#回复: SQL Server 索引基础知识(4)----主键与聚集索引 编辑
谢谢分享,正是我需要的
2008-01-16 21:12:00 | [匿名:ldidici]
#SQL Server 索引基础知识(6)----索引的代价,使用场景 编辑
2008-01-16 14:34:00 | [匿名:ghj1976]
#[导入]SQL Server 索引基础知识(4)----主键与聚集索引 编辑
有些人可能对主键和聚集索引有所混淆,其实这两个是不同的概念,下面是一个简单的描述。不想看绕口文字者,直接看两者的对比表。尤其是最后一项的比较。主键(PRIMARYKEY)来自MSDN的描述:...
2008-01-04 22:30:00 | [匿名:HappyQQ]

发表留言

标题
姓名
邮件
主页
留言 

Powered by: Joycode.MVC引擎 0.5.2.0