Java基础学完,继续深耕(0506)SQL--多表关系

多表关系

一对多(多对一)

一对一

多对多

一对多

场景:部门与员工的关系 (一个部门下有多个员工)。

实现:在数据库表中多的一方,添加字段,来关联一的一方的主键。

现在只是在语法上关联了,但是还需要添加外键约束实现真正关联

可以在创建表时 或 表结构创建完成后,为字段添加外键约束。 具体语法如下:

-- 添加外键约束(为 emp 表中的 dept_id 添加外键关联 dept 表中的 id
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

一对一

案例: 用户 与 身份证信息 的关系

关系: 一对一关系,多用于单表拆分,将一张表的基础字段放在一张表中,其他字段放在另一张表中,以提升操作效率

实现: 在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的(UNIQUE)

-- ============== 一对一 =====================

create table tb_user(

id int unsigned primary key auto_increment comment 'ID',

name varchar(10) not null comment '姓名',

gender tinyint unsigned not null comment '性别, 1 男 2 女',

phone char(11) comment '手机号',

degree varchar(10) comment '学历'
) comment '用户信息表';
insert into tb_user values (1,'白眉鹰王',1,'18812340001','初中'),
(2,'青翼蝠王',1,'18812340002','大专'),
(3,'金毛狮王',1,'18812340003','初中'),
(4,'紫衫龙王',2,'18812340004','硕士');
create table tb_user_card(

id int unsigned primary key auto_increment comment 'ID',

nationality varchar(10) not null comment '民族',

birthday date not null comment '生日',

idcard char(18) not null comment '身份证号',

issued varchar(20) not null comment '签发机关',

expire_begin date not null comment '有效期限-开始',

expire_end date comment '有效期限-结束',

user_id int unsigned not null unique comment '用户ID',

constraint fk_user_id foreign key (user_id) references tb_user(id)
) comment '用户信息表';
insert into tb_user_card values (1,'汉','1960-11-06','100000100000100001','朝阳区公安局','2000-06-10',null,1),
(2,'汉','1971-11-06','100000100000100002','静安区公安局','2005-06-10','2025-06-10',2),
(3,'汉','1963-11-06','100000100000100003','昌平区公安局','2006-06-10',null,3),
(4,'回','1980-11-06','100000100000100004','海淀区公安局','2008-06-10','2028-06-10',4);

多对多

案例: 学生 与 课程的关系

关系: 一个学生可以选修多门课程,一门课程也可以供多个学生选择

实现: 建立第三张中间表,中间表至少包含两个外键,分别关联两方主键

-- ============== 多对多 ==================

create table tb_student(

id int auto_increment primary key comment '主键ID',

name varchar(10) comment '姓名',

no varchar(10) comment '学号'
) comment '学生表';
insert into tb_student(name, no) values ('黛绮丝', '2000100101'),('谢逊', '2000100102'),('殷天正', '2000100103'),('韦一笑', '2000100104');
create table tb_course(

id int auto_increment primary key comment '主键ID',

name varchar(10) comment '课程名称'
) comment '课程表';
insert into tb_course (name) values ('Java'), ('PHP'), ('MySQL') , ('Hadoop');
create table tb_student_course(

id int auto_increment comment '主键' primary key,

student_id int not null comment '学生ID',

course_id int not null comment '课程ID',

constraint fk_courseid foreign key (course_id) references tb_course (id),
constraint fk_studentid foreign key (student_id) references tb_student (id)
)comment '学生课程中间表';

相关推荐
野生技术架构师3 分钟前
一个简单SQL的深度解析
android·数据库·sql
麦聪聊数据7 分钟前
数据库安全与运维管控(五):基于AST的SQL拦截与动态审批
运维·数据库·sql
有味道的男人12 分钟前
电商效率翻倍:用 Open Claw 对接 1688 接口,快速实现图片选品 + 货源监控
java·开发语言·数据库
Omics Pro15 分钟前
马普所:生命蛋白质宇宙聚类
数据库·人工智能·算法·机器学习·数据挖掘·aigc·聚类
BioRunYiXue23 分钟前
AlphaGenome:DeepMind 新作,基因组学迎来 Alpha 时刻
java·linux·运维·网络·数据库·人工智能·eclipse
xiaoyaohou1123 分钟前
025、分布式计算实战:Spark Core与Spark SQL
sql·ajax·spark
神の愛32 分钟前
Mybatis各个属性
数据库·oracle·mybatis
路ZP42 分钟前
放大镜下拉框
java·数据库·sql
万粉变现经纪人1 小时前
如何解决 pip install ta-lib 报错 本地 TA-Lib 库未安装 问题
数据库·python·scrapy·oracle·bug·pandas·pip
|华|1 小时前
Python操作MySQL数据库
数据库·python·mysql