1.主键(PRIMARY   KEY)约束  
      一个表通常可以通过一列和多列组合的数据来唯一标识表中的每一列,这些列和列组合  
  就被称为表上的主键,它可以用来强制实体完整性。  
      当一个表指定了PRIMARY   KEY约束时,SQL   SERVER通过为主键列上建立唯一索引来强制  
  数据的唯一性。唯一性索引在主键被用于查询时可以对数据进行快速访问。  
  2.外键(FOREIGN   KEY)约束  
      外键也是由一列或多列构成的,它用来建立和强制两个表间的关联。这种关联是通过将  
  一个表中的组成主键的列或组合列加入到另一个表中形成的,这个列或组合列就成了第二  
  个表中的外键。  
      一个FOREIGN   KEY约束并不一定要求必须与另一个表上的PRIMARY   KEY约束相关联,它还  
  可以被定义为对另一个列中的UNIQUE约束的一个引用。FOREIGN   KEY约束可以允许空值,但  
  是形成外键的列或组合列中出现空值时将跳过对FOREIGN   KEY约束的验证。当向表中添加新  
  数据行或修改已有的数据行时,在外键中的定义的列或组合列必须在其他表的主键中存在或  
  是为空,否则将会出错。  
  注意:FOREIGN   KEY约束可以对同一个数据库中的其他表上的列或组合列进行引用,也可以  
  是对自身表中其他列或组合列的引用(自引用表)  
      尽管外键的主要作用是用来限制可以输入到外键表中的数据,但是还可以限制对主键表中  
  数据的修改。  
      FOREIGN   KEY约束也可以被用作索引,这是因为:  
      1.对FOREIGN   KEY约束的修改或被在其他表中的FOREIGN   KEY约束所检查  
      2.外键列或组合列也常常被用于查询中,对于在具有FOREIGN   KEY约束的表和其他有主键或  
  唯一键的表间进行查询时,可以在连接准则中使用外键列或组合列。索引允许SQL   SERVER在  
  外键中进行快速查找。但是对这样的索引的创建并不是必需的。
 
--用命令创建主键与外键.
--使用SQL语句创建主键约束可以在创建表(Create Table)或修改表(Alter Table)时进行  创建。
--例创建表时
create table tablename
(
id int (CONSTRAINT pk_id) PRIMARY KEY
)
--例修改表时
ALTER TABLE tablename     --修改表
ADD    
CONSTRAINT tb_PRIMARY
PRIMARY KEY CLUSTERED (列名) /*将你要设置为主键约束的列*/