为表中的现有列添加 PRIMARY KEY 约束时,SQL Server 2005 数据库引擎
将检查现有列的数据和元数据以确保主键符合以下规则:

PRIMARY KEYs 和 UNIQUE KEYs 是类似的, PRIMARY
KEY通常是一列,也有可能多列,通常由他来决定一行数据(row)。
一张表只能有一个 PRIMARY KEY,但可以有很多 UNIQUE KEY。 当给一列设置为
UNIQUE KEY 之后,不能有两行在该列上有相同的数据。 PRIMARY KEY 不允许有
NULL值,但是 UNIQUE KEY 可以。

 

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

网上关于 PRIMARY KEY 和 UNIQUE INDEX 的一段解释:

foreign
key也有两个作用,一是约束作用(constraint),规范数据的引用完整性,但同时也在这个key上建立了一个index;

在创建考试基本表时定义一个名为pk_ks的表级primary key约束,主码为一 cj
int , Results int privary key )个属性组 create table pk_ks( constraint
pk_ks primary key (xh,kch) ) kch int , ID int, 最佳答案 create table
ksjcb (xh int, CourseID int,

可见,key是同时具有constraint和index的意义.

primary
key
 有两个作用,一是约束作用(constraint),用来规范一个存储主键和唯一性,但同时也在此key上建立了一个主键索引;    

如果另一个表中的 FOREIGN KEY 约束引用了 PRIMARY KEY 约束,则必须先删除
FOREIGN KEY 约束。

在MySQL中,对于一个PRIMARY KEY的列,MySQL已经自动对其建立了UNIQUE
INDEX,无需重复再在上面建立索引了。

二是索引(辅助查询用的)。

表包含应用于自身的 PRIMARY XML 索引

DROP INDEX [INDEXName] ON mytable;

索引只是索引,它不会去约束索引的字段的行为(那是key要做的事情)

不能添加违反以上规则的 PRIMARY KEY 约束。

Note that “PRIMARY” is called PRIMARY KEY not INDEX. KEY is something on
the logical level, describes your table and database design (i.e.
enforces referential integrity …) INDEX is something on the physical
level, helps improve access time for table operations. Behind every PK
there is (usually) UNIQUE INDEX created (automatically).

 

如果已存在 PRIMARY KEY 约束,则可以修改或删除它。例如,可以让表的
PRIMARY KEY 约束引用其他列,更改列的顺序、索引名、聚集选项或 PRIMARY KEY
约束的填充因子。但是,不能更改使用 PRIMARY KEY 约束定义的列长度。

如果是 CHAR,VARCHAR 类型,length 可以小于字段实际长度;如果是 BLOB 和
TEXT类型,必须指定 length。

index是数据库的物理结构,它只是辅助查询的,它创建时会在另外的表空间(mysql中的innodb表空间)以一个类似目录的结构存储。索引要分类的话,分为前缀索引、全文本索引等; 

不能有重复的值。如果为具有重复值或允许有空值的列添加 PRIMARY KEY
约束,则数据库引擎 将返回一个错误并且不添加约束。

INDEX
也是数据库的物理结构,但他只有辅助查询作用,它会在创建时占用另外的空间。索引分为前缀索引、全文索引等。索引只是索引,不会去约束索引字段的行为。

key
是数据库的物理结构,它包含两层意义和作用,

可以在创建表时创建单个 PRIMARY KEY
约束作为表定义的一部分。如果表已存在,且没有 PRIMARY KEY
约束,则可以添加 PRIMARY KEY 约束。一个表只能有一个 PRIMARY KEY 约束。

索引也有它的缺点:虽然索引提高了查询速度,却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

unique
key 也有两个作用,一是约束作用(constraint),规范数据的唯一性,但同时也在这个key上建立了一个唯一索引;

列不允许有空值。创建表时指定的 PRIMARY KEY 约束列隐式转换为 NOT NULL。

创建索引时,需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE
子句的条件)。
实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

                                                                
主键列不能包含 NULL 值;

相关文章