- SQL seriver 用T-sql 创建外键
1.建表时创建外键
create table 从表
...
“foreign key (关联字段) references 主表(关联字段)"
...
go
2.建完表后,在表外部单独添加外键
--添加外键约束(关联字段要用括号括起来)
ALTER TABLE 从表
ADD CONSTRAINT 约束名 FOREIGN KEY (关联字段) references 主表(关联字段);
- 删除外键
--删除约束
ALTER TABLE 表名 DROP CONSTRAINT 约束名;
Q:主表是什么呢?从表又是什么呢?
A:若同一个数据库中,B表的外键与A表的主键相对应,则A表为主表,B表为从表。
例如:
假设学生表(学号,姓名,性别,专业号),专业表(专业号,专业名称),则学生表中的专业号为学生表的外键,其与专业表中“专业号”属性相关联,因此,专业表为主表,学生表为从表。
Q2:外键有什么作用呢?
A2:外键的主要作用是:保持数据的一致性、完整性。
#####################################################
可以理解为如果你对A表添加了外键,那么当你要为A表插入数据时,DBMS会自动帮你检查你插入的数据,B表的主键是否有,如果没有,数据库会报错…提醒你要为B表添加数据
再深入的思考会发现,这个问题涉及到计算思维的问题,我们可以”看到“两个表可以通过某个关联字段关联起来,但是计算机没有眼睛,它看不到,我们只能告诉它“外键”。
通过外键,他会帮我们自动检查数据是否存在,以次来确保数据一致性。如果没有外键我们做内连接进行查询时可能就会查询结果不全,通过声明外键,让DBMS帮助我们检测,避免此类现象的发生。