55.1 外键关系/约束
外键用于定义两个表之间的关系。父表必须拥有主键以唯一标识行;子表的某一列存放父表主键的值。FOREIGN KEY REFERENCES 约束保证:子表中的值必须存在于父表主键中。
示例:父表 Company 含主键 CompanyId,子表 Employee 存放公司编号。
sql
create table Company (
CompanyId int primary key,
Name nvarchar(200)
)
create table Employee (
EmployeeId int,
Name nvarchar(200),
CompanyId int foreign key references Company(CompanyId)
)
约束确保:Employee.CompanyId 必须存在于 Company.CompanyId;若存在对应员工,则无法删除该公司。
55.2 维护父子行关系
假设 Company 表已存在 CompanyId = 1 的行,可插入对应员工:
sql
insert into Employee values (17,'John',1)
若插入不存在的 CompanyId,将报错:
sql
insert into Employee values (17,'John',111111)
-- 错误 547:与外键冲突
只要子表存在对应行,就无法删除父表记录:
sql
delete from company where CompanyId = 1
-- 错误 547:与引用约束冲突
外键保证两表行级关系完整性。
55.3 在现有表上添加外键关系
若已存在 Company、Employee 表,且 Employee 已有 CompanyId 列,可用 ALTER TABLE 追加外键:
sql
alter table Employee add foreign key (CompanyId) references Company(CompanyId)
55.4 在现有表上新增外键列
若 Employee 表尚无 CompanyId 列,可一次性添加列并声明外键:
sql
alter table Employee add CompanyId int foreign key references Company(CompanyId)
55.5 获取外键约束信息
系统视图 sys.foreign_keys 返回数据库所有外键关系:
sql
select
name,
OBJECT_NAME(referenced_object_id) as [父表],
OBJECT_NAME(parent_object_id) as [子表],
delete_referential_action_desc,
update_referential_action_desc
from sys.foreign_keys