mysql多表联查

本文介绍了数据库中的一对一、一对多、多对一、多对多四种关系,以及内连接、左连接和右连接的使用。通过实例展示了如何进行单行和多行子查询,并详细阐述了SQL查询的执行顺序。内容涵盖了数据库设计和SQL操作的基础知识。

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

表的关系分为四种:

  • 一对一 one to one QQ和QQ邮箱,员工和员工编号
  • 一对多 one to many 最常见,部门和员工,用户和订单
  • 多对一 many to one 一对多反过来,员工和部门,订单和用户
  • 多对多 many to many 老师和学生,老师和课程

三种连接 join

  • 内连接 inner join
  • 左(外)连接 left join
  • 右(外)连接 right join

单行子查询

select * from laoshi where laoshi=any(select laoshi from xuesheng where laoshi='b老师');

select * from laoshi where laoshi=any(select laoshi from xuesheng where laoshi='a老师');

多行子查询

select * from laoshi where laoshi in (select * from xuesheng where laoshi='a老师');

left join

SELECT l.laoshi,x.xingming

FROM laoshi l INNER JOIN xuesheng x

                      ON l.laoshi=x.laoshi

WHERE l.laoshi='a老师';

  • INNER JOIN两边都对应有记录的才展示,其他去掉
  • LEFT JOIN左边表中的数据都出现,右边没有数据以NULL填充
  • RIGHT JOIN右边表中的数据都出现,左边没有数据以NULL填充

 SQL的执行顺序


(1) FROM [left_table] 选择表
 
(2) ON <join_condition> 链接条件
 
(3) <join_type> JOIN <right_table> 链接
 
(4) WHERE <where_condition> 条件过滤
 
(5) GROUP BY <group_by_list> 分组
 
(6) AGG_FUNC(column or expression),... 聚合
 
(7) HAVING <having_condition> 分组过滤
 
(8) SELECT (9) DISTINCT column,... 选择字段、去重
 
(9) ORDER BY <order_by_list> 排序
 
(10) LIMIT count OFFSET count; 分页
 

.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值