数据库操作中,左连接,右连接是什么意思,举例说明

如题所述

第1个回答  2018-12-11

左连接:只要左边表中有记录,数据就能检索出来,而右边有的记录必要在左边表中有的记录才能被检索出来。

右连接:右连接是只要右边表中有记录,数据就能检索出来。

举例说明

新建两张表,分别为t_left_tab和t_right_tab。

将t_left_tab作为左边表,t_right_tab作为右边。

左连接:SELECT * FROM t_left_tab a LEFT JOIN t_right_tab b ON a.`id` = b.`id`; 

查询结果:

右连接:SELECT * FROM t_right_tab a LEFT JOIN t_left_tab b ON a.`id` = b.`id`;

查询结果:

查询最大条数:SELECT * FROM t_left_tab a LEFT JOIN t_right_tab b ON 1=1; 

查询结果:

3、总结

A 数据库左连接和右连接的区别:主表不一样。

B 通过左连接和右连接,最小条数为3(记录条数较小的记录数),最大条数为12(3×4)。 

扩展资料:

数据库中的自连接:

自连接(self join)可以把它这个过程想象成两张一样的表进行左连接或右连接,其中一张表通过设别名的方式成为了虚表,但是共享原标中的信息。

应用场景:就是表的一个字段和另一个字段是相同性质的东西,譬如员工与上司,他们本质也都是员工。

在员工表中,员工的直接上司编号会以另一个字段的形式出现,但是他的上司的编号也是会出现在员工编号这个字段里。

那么在这种情况下,假如需要去查询某一位员工的上司的信息,在已知该员工编号的条件下,可以根据他的编号去获得上司的编号,进而通过上司的编号去获得上司的信息。

举个例子:

empId      empName      empLeaderId

1             张三                   4

2             李四                   7

3             王麻子               7

4             陈六                   8

5             周日                   7

6             王八                   8

7        郝九      8

8     M10      null

上面的表名为Employee,那么我要查询李四的上司的信息,对应的sql语句应该是这样的:

select *from  Employee e1 left join Employee e2 on e1.empLeaderId=e2.empId where e1.empId=2;

参考资料来源:百度百科-MySQL数据库



相似回答