SQL Server笔记 -- 第55章:外键

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
相关推荐
小的~~24 分钟前
使用StreamLoad向Doris-4.0.3版本的聚合表导数据超时问题
运维·服务器·数据库
Roselind_Yi24 分钟前
云计算实验实操|Keystone安装配置+CloudSim仿真平台部署(超详细图文版)
java·经验分享·笔记·ubuntu·云计算·vim·虚拟机
zwenqiyu24 分钟前
zwq重链剖分学习笔记,从入门到过掉模板题
笔记·学习
笑梦无境28 分钟前
mysql基础篇一(多年前整理)
数据库·mysql
Yushan Bai29 分钟前
HP-UX平台Oracle启动实例遭遇ORA-27300/ORA-27301/ORA-27302报错
数据库·oracle·ux
山佳的山29 分钟前
Kingbase 身份认证与权限控制实践—数据库安全的第一道防线
数据库
云边散步32 分钟前
godot2D游戏教程系列二(25)
笔记·学习·音视频·游戏开发
深蓝轨迹34 分钟前
解决Redis排序后MySQL查询乱序问题:从原因到落地(通用版)
数据库·redis·笔记·mysql·bug
守护安静星空38 分钟前
ubuntu vscode 调试 at32f435vmt7基于AT32IDE
linux·运维·笔记·vscode·ubuntu
jnrjian43 分钟前
预估 PURGE DBA_RECYCLEBIN 执行时间 v$SESSION_LONGOPS 6 秒限制
数据库·dba