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在
外键中进行快速查找。但是对这样的索引的创建并不是必需的。
外键 (FK)
是用于建立和加强两个表数据之间的链接的一列或多列。通过将保存表中主键值的一列或多列添加到另一个表中,可创建两个表之间的链接。这个列就成为第二个表的外键。
当创建或更改表时可通过定义
FOREIGN
KEY
约束来创建外键。
例如,数据库
pubs
中的
titles
表与
publishers
表有链接,因为在书名和出版商之间存在逻辑联系。titles
表中的
pub_id
列与
publishers
表中的主键列相对应。titles
表中的
pub_id
列是到
publishers
表的外键。
FOREIGN
KEY
约束并不仅仅只可以与另一表的
PRIMARY
KEY
约束相链接,它还可以定义为引用另一表的
UNIQUE
约束。FOREIGN
KEY
约束不允许空值,但是,如果任何组合
FOREIGN
KEY
约束的列包含空值,则将跳过
FOREIGN
KEY
约束的校验。
说明
FOREIGN
KEY
约束可引用同一数据库中的表或同一表(自引用表)内的列,例如,一个包含下面三列的雇员表:employee_number、employee_name
和
manager_
employee_number。由于经理本身也是雇员,所以从
manager_employee_number
列到
employee_number
列存在外键关系。
尽管
FOREIGN
KEY
约束的主要目的是控制存储在外键表中的数据,但它还可以控制对主键表中数据的修改。例如,如果在
publishers
表中删除一个出版商,而这个出版商的
ID
在
titles
表中记录书的信息时使用了,则这两个表之间关联的完整性将被破坏,titles
表中该出版商的书籍因为与
publishers
表中的数据没有链接而变得孤立了。FOREIGN
KEY
约束防止这种情况的发生。如果主键表中数据的更改使之与外键表中数据的链接失效,则这种更改是不能实现的,从而确保了引用完整性。如果试图删除主键表中的
行或更改主键值,而该主键值与另一个表的 FOREIGN
KEY
约束值相关,则该操作不可实现。若要成功更改或删除
FOREIGN
KEY
约束的行,可以先在外键表中删除外键数据或更改外键数据,然后将外键链接到不同的主键数据上去。