【JavaWeb】Mysql多表和事务

一、多表设计之外键约束

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);

删除其中的某个部门(是否可以):

  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多表设计之多表分析及创建

完成一个学校的选课系统,在选课系统中包含班级,学生和课程这些实体。
班级和学生之间是有关系存在:
一个班级下包含多个学生,一个学生只能属于某一个班级(一对多的关系)。
学生和课程之间是有关系存在:
一个学生可以选择多门课程,一门课程也可以被多个学生所选择(多对多的关系)。
多表的创建
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值