什么时候用mysql左关联_mysql – 何时使用左外连接?

连接用于将两个相关的表组合在一起。

在您的示例中,您可以组合Employee表和Department表,如下所示:

SELECT FNAME, LNAME, DNAME

FROM

EMPLOYEE INNER JOIN DEPARTMENT ON EMPLOYEE.DNO=DEPARTMENT.DNUMBER

这将产生如下记录:

FNAME LNAME DNAME

----- ----- -----

John Smith Research

John Doe Administration

我在上面使用了INNER JOIN。 INNER JOINs组合了两个表,以便只显示两个表中匹配的记录,在这种情况下,在部门号(员工中的DNO,部门表中的DNUMBER)中加入。

当您在第一个表中有记录但在第二个表中可能没有记录时,LEFT JOIN允许您组合两个表。例如,假设您需要所有员工的列表,以及任何家属:

SELECT EMPLOYEE.FNAME as employee_first, EMPLOYEE.LNAME as employee_last, DEPENDENT.FNAME as dependent_last, DEPENDENT.LNAME as dependent_last

FROM

EMPLOYEE INNER JOIN DEPENDENT ON EMPLOYEE.SSN=DEPENDENT.ESSN

这里的问题是,如果员工没有受扶养人,那么他们的记录根本就不会出现 – 因为DEPENDENT表中没有匹配的记录。

所以,您使用左连接,将所有数据保存在“左”(即第一个表)上,并在“右”(第二个表)上拉入任何匹配的数据:

SELECT EMPLOYEE.FNAME as employee_first, EMPLOYEE.LNAME as employee_last, DEPENDENT.FNAME as dependent_first, DEPENDENT.LNAME as dependent_last

FROM

EMPLOYEE LEFT JOIN DEPENDENT ON EMPLOYEE.SSN=DEPENDENT.ESSN

现在我们得到所有的员工记录。如果给定员工没有匹配的依赖项,则dependent_first和dependent_last字段将为null。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值