左连接:只要左边表中有记录,数据就能检索出来,而右边有的记录必要在左边表中有的记录才能被检索出来。
右连接:右连接是只要右边表中有记录,数据就能检索出来。
举例说明
新建两张表,分别为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数据库