连接用于将两个相关的表组合在一起。
在您的示例中,您可以组合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。