多表查询的各种连接方式

本文详细解读了SQL查询中的笛卡尔积,以及内连接、左外连接、右外连接和全外连接的区别。通过实例说明如何避免笛卡尔积的错误展示,并重点介绍了使用部门编号进行等值连接的内连接和不同类型的外连接操作。

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

笛卡尔积

  • 查询出来的数据记录以相乘的形式展现
  • select * from emp, dept;
  • A表记录 * B表记录
    一定要避免这种形式。

内连接

以表中某一字段作为等值连接条件。
内连接,在结果集中只显示通过条件连接在一起的记录。
select * from emp e,dept d where e.depno = d.depno;
select * from emp e inner join dept d on e.deptno = d.depno;

外连接:悬浮记录在结果集中显示

左外链接

跨表查询时左边表里的字段在右边的表里找不到匹配字段的记录也加入到查询结果集
右边表里的字段在左边的表里找不到匹配字段的记录不加入到查询结果集
select * from emp e, dept d where e.depno = d.depno(+),表示在右边的表里面需要构造空数据,也就是左连接。

右外连接

跨表查询时右边表里的字段在右边的表里找不到匹配字段的记录也加入到查询结果集
左边表里的字段在左边的表里找不到匹配字段的记录不加入到查询结果集
select * from emp e, dept d where e.depno(+) = d.depno,表示在左边的表里面需要构造空数据,也就是右连接。

全外连接

跨表查询时左边表里的字段在右边表里找不到匹配字段的记录加入到查询结果集,右边表里的字段在左边表里找不到匹配字段的记录也加入到查询结果集中。

select * from emp e full outer join dept d on e.depno = d.depno;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值