文章目录
一、多表设计之外键约束
1.约束的作用
约束是用来保证数据的完整性。
1.1单表约束
- 主键约束
- 唯一约束
- 非空约束
1.2多表约束
外键约束:用来保证数据完整性(多表之间)。
1.2.1演示外键约束作用
创建一个部门表:
create table dept(
did int primary key auto_increment,
dname varchar(20)
);
insert into dept values (null,'市场部');
insert into dept values (null,'人事部');
insert into dept values (null,'教研部');
创建一个员工表:
create table employee(
eid int primary key auto_increment,
ename varchar(20),
salary double,
birthday date,
sex varchar(10),
dno int
);
insert into employee values (null,'张三',8000,'1988-09-01','男',3);
insert into employee values (null,'李四',9000,'1988-09-01','男',1);
insert into employee values (null,'王五',6000,'1988-09-01','男',2);
insert into employee values (null,'赵六',10000,'1988-09-01','男',3);
insert into employee values (null,'孙七',10000,'1988-09-01','男',1);
删除其中的某个部门(是否可以):
- 查看数据
向员工表中插入一条记录(没有部门):
insert into employee values (null,'田八',10000,'1988-09-01','男',null);
删除一个人事部
delete from dept where did = 2;
向刚才做的这两个操作(插入一个没有部门的员工,删除一个带有员工的部门)。这种情况都是不应该发生。这个时候需要在多表之间添加外键约束。
1.3添加外键约束
1.3.1在员工表上添加外键
alter table employee add foreign key (dno) references dept(did);
1.3.2 设置外键为非空
alter table employee modify dno int not null;
二、多表设计之表关系的介绍
1.1一对多的关系
一对多的例子:
一个部门下可以有多个员工,一个员工只能属于某一个部门。
1.1.1一对多关系的建表原则:
在多的一方创建外键指向一的一方的主键
1.2 多对多的关系
多对多的例子:
一个学生可以选择多门课程,一门课程可以被多个学生选择。
1.2.1多对多的建表的原则:
需要创建中间表,中间表中至少两个字段,分别作为外键指向多对多双方的主键
1.3 一对一的关系
一对一的例子:
一个公司可以有一个注册地址,一个注册地址只能对一个公司。
1.3.1一对一关系建表原则:
唯一外键对应:假设是一对多,在多的一方创建外键指向一的一方的主键,将外键设置为unique。
主键对应:将两个表的主键建立对应关系即可。
1.4多表设计之多表分析及创建
完成一个学校的选课系统,在选课系统中包含班级,学生和课程这些实体。
班级和学生之间是有关系存在:
一个班级下包含多个学生,一个学生只能属于某一个班级(一对多的关系)。
学生和课程之间是有关系存在:
一个学生可以选择多门课程,一门课程也可以被多个学生所选择(多对多的关系)。
多表的创建