SQL seriver 外键约束小结

  • 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帮助我们检测,避免此类现象的发生。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值