mysql – 何时使用左外连接? - 代码日志

mysql – 何时使用左外连接?

我不明白左外连接的概念,右外连接,或者为什么我们需要使用连接!我正在努力的问题,我正在工作的表格在这里:http://www.cs.ucc.ie/pipermail/cs2501.2011/attachments/20110323/4288bee0/attachment-0001.pdf

问题3(b)

在SQL中构造一个命令来解决以下查询,解释为什么它必须使用
(外部)联接方法。 [5个标记]
“找到每个工作人员及其所属配偶的姓名,如果有的话”

问题3(c) –

在SQL中构造一个命令来解决以下查询,使用(i)连接方法,和(ii)
子查询方法。 [10个标记]
“找到工作20多个小时的每个工作人员的身份名称
电脑化项目“

任何人都可以简单地向我解释一下

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

在您的示例中,您可以组合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。

http://stackoverflow.com/questions/5874733/when-to-use-a-left-outer-join

本站文章除注明转载外,均为本站原创或编译
转载请明显位置注明出处:mysql – 何时使用左外连接?