表关系管理

表关系管理

1、概述

​ 表与表之间的关系可以是一对一、一对多、多对一的。通过外键把表连接起来,外键放在任意一张表都可以,通常选择由从表(相对次要的表)来持有外键(因为一旦删除数据,删除从表,外键也一并被删除,主表不会留下脏数据)。

课程表:

这里写图片描述

学生表:

这里写图片描述

选课表:

这里写图片描述

选课表:就是中间表。

表关系管理之多对多:通过中间表进行管理,中间表同时持有双方外键,中间表的主键是双方外键的联合主键

创建【学生_课程】中间表
create table student_course(
sid integer not null,

cid integer not null,

primary key (sid,cid)
);

– 如果没有设置主键,可以通过修改表字段的方式来添加【联合主键】
– alter table student_course add constraint s_c primary key (sid,cid);

Create Table
CREATE TABLE student_course ( sid int(11) NOT NULL, cid int(11) NOT NULL, PRIMARY KEY (sid,cid)) E
2、外键管理
2.1 定义外键

foreign key 从表名(classid) references 主表名(id)

2.2 追加外键
方法一:
ALTER TABLE student ADD CONSTRAINT FK_student_aclass 
FOREIGN KEY student(classid) REFERENCES aclass(id);

方法二:
ALTER TABLE temp ADD FOREIGN KEY temp(cid) REFERENCES clazz(id);
2.3 删除外键
show create table student; --找出classid对应的外键名称
alter table student drop foreign key FK_student_aclass; 删除外键名称
alter table student drop classid;

这样定义外键使用起来不够灵活,不能够给外键设置默认值,外键中的值必须是主表中存在的。在实际应用中给从表设置一个键,直接用来当作外键使用,不用加外键(foreign key)修饰。

猜你喜欢

转载自blog.csdn.net/lm_is_dc/article/details/80298236