MySQL多表创建关联及操作
创始人
2025-01-15 08:06:22
0

表与表之间的关系


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

一对多的关系

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

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

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(

oid varchar(50),

pid varchar(50)

);

关联两张表

alter table orderitem add constraint orderitem_fk foreign key(oid) references orders(oid);

alter table orderitem add constraint orderitem1_fk foreign key(pid) references product(pid);

多表查询操作


1. 交叉连接查询(基本不会用到 - 得到的是两个表的乘积)

select * from A,B

select * from category,product;

内容是乱的!第一张表3条数据,第二张表9条数据,一共 3*9 = 27 条数据。

2. 内连接查询(使用关键字 inner join   – inner可以省略)

隐式内连接

select * from A,B where 条件

select * from category c,product p where c.cid = p.category_id;

显式内连接

select * from A inner join B on 条件

select * from category inner join product on cid=category_id;

select * from category join product on cid=category_id;

3. 外连接查询(使用关键字 outer join   --outer可以省略)

左外连接:left outer join

select * from A left outer join B on 条件

select * from category left join product on cid=category_id;

右外连接 right outer join

select * from A right outer join B on 条件;

select * from category right join product on cid=category_id;

左右连接的区别:

左连接:左边的数据全部查出来。category数据全部出来。

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

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

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

img

img

img

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

如果你觉得这些内容对你有帮助,可以扫码领取!

img

Kafka进阶篇知识点

image

Kafka高级篇知识点

image

44个Kafka知识点(基础+进阶+高级)解析如下

image

由于篇幅有限,小编已将上面介绍的**《Kafka源码解析与实战》、Kafka面试专题解析、复习学习必备44个Kafka知识点(基础+进阶+高级)都整理成册,全部都是PDF文档**

36.jpg" alt=“img” style=“zoom: 33%;” />

Kafka进阶篇知识点

[外链图片转存中…(img-Eic7JjJV-1711404739320)]

Kafka高级篇知识点

[外链图片转存中…(img-ZnRkbcku-1711404739321)]

44个Kafka知识点(基础+进阶+高级)解析如下

[外链图片转存中…(img-IJF8itja-1711404739321)]

由于篇幅有限,小编已将上面介绍的**《Kafka源码解析与实战》、Kafka面试专题解析、复习学习必备44个Kafka知识点(基础+进阶+高级)都整理成册,全部都是PDF文档**

需要更多Java资料的小伙伴可以帮忙点赞+关注,点击传送门,即可免费领取!

相关内容

热门资讯

一分钟了解!阿当比鸡有挂吗,大... 阿当比鸡有挂吗是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信...
科技介绍!欢乐达人暗堡破解,聚... 聚友联盟免费辅助器是一款专注玩家量身打造的游戏记牌类型软件,在聚友联盟免费辅助器这款游戏中我们可以记...
实测教程!四川游戏家园免费透视... 您好:四川游戏家园免费透视这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户...
避坑细节!新超凡软件辅助,微信... 避坑细节!新超凡软件辅助,微信微乐小程序辅助软件,固有有开挂辅助软件(详细教程)这是一款可以让一直输...
我来教教你!极速鱼虾蟹辅助,斗... 大家好,今天小编来为大家解答极速鱼虾蟹辅助这个问题咨询软件客服可以免费测试直接加微信(1367043...
玩家必看科普!免费游戏辅助软件... 玩家必看科普!免费游戏辅助软件,新道游开挂视频,原先有开挂辅助器(有挂教程);亲,免费游戏辅助软件这...
分辨真假!赣湘互娱透视挂,情怀... 分辨真假!赣湘互娱透视挂,情怀宜春辅助,传授开挂辅助插件(真的有挂);无需打开直接搜索薇:13670...
科技通报!指尖辅助,心悦填大坑... 心悦填大坑辅助方法是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我...
1.9分钟了解!免费天天贵阳辅... 1.9分钟了解!免费天天贵阳辅助工具,牵手游戏辅助,曝光辅助开挂插件(有挂头条);无需打开直接搜索加...
大神推荐!白金岛十胡卡辅助,鱼... 鱼虾蟹辅助视频教程开挂教程视频分享装挂详细步骤在当今的网络游戏中,鱼虾蟹辅助视频教程作为一种经典的娱...