SQL - JOIN

外联接
    外联接可以是左向外联接、右向外联接或完整外部联接。在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:
1.  LEFT JOIN 或 LEFT OUTER JOIN。
  左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
2. RIGHT JOIN 或 RIGHT OUTER JOIN。
 右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
3. FULL JOIN 或 FULL OUTER JOIN。
 完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
内联接
 仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回 FROM 子句中提到的至少一个表或视图的所有行,只要这些行符合任何 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回。
例题
Given the following table definitions:
DEPARTMENT

deptno CHAR(3)
deptname CHAR(30)
mgrno INTEGER
admrdept CHAR(3)
 
EMPLOYEE
empno INTEGER
firstname CHAR(30)
midinit CHAR
lastname CHAR(30)
workdept CHAR(3)

Which of the following statements will list every employee's number and last name with
the employee number and last name of their manager, including employees without a
manager?

a) SELECT e.empno, e.lastname, m.empno, m.lastname FROM employee e LEFT INNER
  JOIN department INNER JOIN employee m ON mgrno = m.empno ON e.workdept = deptno
b) SELECT e.empno, e.lastname, m.empno, m.lastname FROM employee e LEFT OUTER
  JOIN department INNER JOIN employee m ON mgrno = m.empno ON e.workdept = deptno
c) SELECT e.empno, e.lastname, m.empno, m.lastname FROM employee e RIGHT OUTER JOIN
   department INNER JOIN employee m ON mgrno = m.empno ON e.workdept = deptno
d) SELECT e.empno, e.lastname, m.empno, m.lastname FROM employee e RIGHT INNER JOIN
联接选择:1. department要显示出匹配的以及为空的行,所以选择外联接,而且需要显示出employee表(左表)的内容,所以选择左外联接
             2. employee manager只显示出匹配行,所以选择内联接,内联接不分左右

答案:B

posted on 2005-12-09 15:16  盼盼508  阅读(347)  评论(0编辑  收藏  举报