MySQL多表创建关联及操作

这篇博客详细介绍了MySQL中如何使用外键创建和管理表间关联,包括外键的特点、实际操作步骤、目的、注意事项,以及一对多、多对多和一对一的关系。通过示例展示了如何创建和解除外键约束,强调了外键对于保证数据完整性的关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

外键特点

1. 从表外键的值是对主键的引用。

2. 从表外键类型必须与主表主键类型一致。

声明外键约束

语法:

alter table 从表 add[constraint] [外键名称] foreign key (从表外键在字段名)references 主表(主表的主键);

[外键名称] 用于删除外键约束的,一般建议 “ _fk ”结尾。

alter table 从表 drop foreign key 外键名称

实际操作

创建数据库

创建分类表

1.分类表

create table category(

cid varchar(32) primary key,

cname varchar(100)

);

创建商品表

2.商品表

create table product(

pid varchar(32) primary key,

pname varchar(40),

price double,

category_id varchar(32)

);

设置编码格式

set name gbk;

添加点数据

insert into category(cid,cname) values(‘c001’,‘家电’);

insert into category(cid,cname) values(‘c002’,‘服饰’);

insert into category(cid,cname) values(‘c003’,‘化妆品’);

insert into product(pid,pname,price,category_id) values(‘p001’,‘联想’,‘5000’,‘c001’);

insert into product(pid,pname,price,category_id) values(‘p002’,‘海尔’,‘5000’,‘c001’);

insert into product(pid,pname,price,category_id) values(‘p003’,‘雷神’,‘5000’,‘c001’);

insert into product(pid,pname,price,category_id) values(‘p004’,‘JACK JONES’,‘800’,‘c002’);

insert into product(pid,pname,price,category_id) values(‘p005’,‘真维斯’,‘200’,‘c002’);

insert into product(pid,pname,price,category_id) values(‘p006’,‘花花公子’,‘440’,‘c002’);

insert into product(pid,pname,price,category_id) values(‘p007’,‘劲霸’,‘2000’,‘c002’);

insert into product(pid,pname,price,category_id) values(‘p008’,‘香奈儿’,‘800’,‘c003’);

insert into product(pid,pname,price,category_id) values(‘p009’,‘相宜本草’,‘200’,‘c003’);

最后一列 category_id 列在创建表的时候自己定义的,如果没有,则可以使用一下命令添加一列。

alter table product add category_id

链接两张表

alter table product add foreign key(category_id) references category(cid);

两张表已经关联,主表有外键约束。不能轻易删除主表数据,因为从表有他的记录。

要想解除关系,先删除从表对他有关系的数据删除,再删除主表数据。

使用外键的目的

保证数据的完整性。

注意事项

从表外键不能添加主表中不存在的记录。

主表不能删除从表中已经引用的记录。

表与表之间的关系


表语表之间的关系,说的就是表与表数据之间的关系。

一对多的关系

常见的实例:客户和订单,分类和商品,部门和员工。

一对多建表原则:在从表(多方)创建一个字段,字段作为外键指向主表的主键。

alter table 从表 add [constraint][外键名称] foreign key(从表外键在字段名) references 主表(主表的主键);

多对多的关系

常见的实例:学生和课程,商品和订单,演员和角色。

多对多关系建立表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。

建立关系

alter table stu_course add foreign key(sno) references stu(sid);

alter table stu_course add foreign key(sno) references course(cid);

一对一关系(了解)

在实际开发中应用不多,因为一对一可以创建成一张表。

两种建表原则:

外键唯一:主表的主键和从简的外键唯一,形成主外键关系,外键唯一 unique。

外键是主键:主表的主键和从表的主键,形成主外键关系。

多对多连接

实现如下表结构:

创建订单表

create table orders(

oid varchar(32) primary key,

totalprice double

);

创建经单项的表(中间表)

create table orderitem(

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

这个月马上就又要过去了,还在找工作的小伙伴要做好准备了,小编整理了大厂java程序员面试涉及到的绝大部分面试题及答案,希望能帮助到大家

在这里插入图片描述

在这里插入图片描述

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
-community.csdnimg.cn/images/e5c14a7895254671a72faed303032d36.jpg" alt=“img” style=“zoom: 33%;” />

总结

这个月马上就又要过去了,还在找工作的小伙伴要做好准备了,小编整理了大厂java程序员面试涉及到的绝大部分面试题及答案,希望能帮助到大家

[外链图片转存中…(img-z4Q5ywun-1712654158627)]

[外链图片转存中…(img-mZWLGpTM-1712654158627)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值