none
为何要给表建立主键,主键有什么作用?建立索引的列是如何提高搜索速度的? RRS feed

答案

  • 表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。 一个表只能有一个 PRIMARY KEY 约束,并且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束可保证数据的唯一性,因此经常对标识列定义这种约束。 如果为表指定了 PRIMARY KEY 约束,则 SQL Server 2005 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。 创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 PRIMARY KEY 约束。



    为什么创建索引
    http://www.sqlteam.com/article/sql-server-indexes-the-basics


    有dba的职位吗
    2009年11月13日 5:17
    版主
  • 每个表里多行数据。一般来说数据库对表的默认排序是按着主键来的,
    当你没对某个字段设置主键的时候你会发现 数据表的数据并不会是按者id增加的顺序而排列的。
    在用sql查询语言对数据进行提取操作的时候。
    如果你要提出所有数据,那么加主键对搜索速度没有影响的。
    而比如你的条件是id>100 and id<300   对于建立了主键的表
     查询会根据id一直找到100然后开始提取数据  一直到300 
    当然如果你的查询条件更复杂 可以将主键设到其它更关键的字段,设置后查询效果十分明显。
    索引就是预先对数据表的一个字段或多个字段按升序或将序的排列的一种类似目录的标签。  这个标签是键创建索引的时候就生存,会占用一定的空间。

    2009年11月13日 15:29

全部回复

  • 表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。 一个表只能有一个 PRIMARY KEY 约束,并且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束可保证数据的唯一性,因此经常对标识列定义这种约束。 如果为表指定了 PRIMARY KEY 约束,则 SQL Server 2005 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。 创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 PRIMARY KEY 约束。



    为什么创建索引
    http://www.sqlteam.com/article/sql-server-indexes-the-basics


    有dba的职位吗
    2009年11月13日 5:17
    版主
  • 每个表里多行数据。一般来说数据库对表的默认排序是按着主键来的,
    当你没对某个字段设置主键的时候你会发现 数据表的数据并不会是按者id增加的顺序而排列的。
    在用sql查询语言对数据进行提取操作的时候。
    如果你要提出所有数据,那么加主键对搜索速度没有影响的。
    而比如你的条件是id>100 and id<300   对于建立了主键的表
     查询会根据id一直找到100然后开始提取数据  一直到300 
    当然如果你的查询条件更复杂 可以将主键设到其它更关键的字段,设置后查询效果十分明显。
    索引就是预先对数据表的一个字段或多个字段按升序或将序的排列的一种类似目录的标签。  这个标签是键创建索引的时候就生存,会占用一定的空间。

    2009年11月13日 15:29