连接查询之外连接(左外链接和右外连接)

内连接:

       假设A表和B表进行连接查询,使用内连接的话,凡是A表和B表能够匹配上的记录被查询出来,这就是内连接。A、B两张表没有主副之分,两张表是平等的

外连接:

       假设A表和B表进行连接查询,使用外连接的话,A、B两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表内容,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。

外连接的分类?

        左外连接(也称左连接):表示左边的这张表是主表。

        右外连接(也称右连接):表示右边的这张表是主表。

        左连接有右连接的写法,右连接也会有对应的左连接的写法。

案例:

        需求:找出每个员工的上级领导?(要求显示出所有员工姓名。)

        分析:我们在自连接中查出了13条记录,显然不符合本需求,因为本需求需要显示所有员工,为此应该显示14条记录所以此处我们应该使用外连接进行查询

        SQL:(左连接)

        select

                a.ename as '员工名称',b.ename as '领导姓名'                         #这里的as可以省略

        from

                emp a                                                                                       #这里省略了as

        left outer join   #这里的outer 表示外连接,可以省略,left表示左连接,

                emp b                                                                                       #这里也省略了as

        on

                a.mgr = b.empno;

                         

将上面的左连接写成右连接的形式如下:

SQL:(右连接)

select

a.ename '员工姓名',b.ename '领导姓名'        #这里省略了as

from

emp b                                                                      #这里也省略了as

right join                                                                         #这里的省略了outer

emp a                                                                       #这里省略了as

on

a.mgr = b.empno;

        ​​​​​​​        ​​​​​​​        

无论是左连接还是右连接显示的查询结果一样。

外连接最重要的特点是:主表的数据无条件的全部查询出来。

如何区分外连接和内连接:join前面是否有leftright,有其中任意一个就是外连接,一个都没有就是内连接。

在实际开发中外连接使用较多。

【外连接的查询结果条数一定是大于等于内连接的查询结果条数(正确)】

案例:查询没有员工的部门信息

试着写一条SQL语句,查询出emp表所有信息和dept表所有信息,采用外连接dept是主表没有员工的部门信息也能显示

        select

                e.*, d.*

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno;

分析查询结果我们只需要最后一条信息,所以还需要增加条件语句,对上面的SQL语句进行修改。

        select

                e.*, d.*

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno

        where

                e.ename is null;

观察查询结果,我们对前面的内容也是不需要的,所以继续对上面的SQL语句进行修改

        select

                d.deptno,d.dname,d.loc

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno

        where

                e.ename is null;

        ​​​​​​​        ​​​​​​​        ​​​​​​​

这才是我们需要的结果。

[注意:很多查询语句我们不可能一子就从头到尾完整的写出来,需要将需求进行分解,每次完成一部分,通过不断调试,最后才能写出完整的查询语句。]

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值