日期:2014-05-16  浏览次数:20587 次

oracle 内连接 左外连接 右外连接的用法,(+)符号用法

1. 内连接很简单
select A.*, B.* from A,B where A.id = B.id
select A.*, B.* from A inner join B on A.id = B.id
以上两句是完全等价的

2. 左外连接?
select * from emp a left join dept d on a.deptno=d.deptno
select * from emp a,dept d where a.deptno=d.deptno(+)

以上两句是完全等价的

3. 右外连接
select * from emp a right join dept d on a.deptno=d.deptno
select * from emp a,dept d where a.deptno(+)=d.deptno
以上两句是完全等价的

也就是说只要把语句中的表换个位置,右外和左外就可以起到同样的功能

?

?

?

?

Oracle中可以使用“(+) ”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN?

LEFT OUTER JOIN:左外关联?
SELECT e.last_name, e.department_id, d.department_name?
FROM employees e?
LEFT OUTER JOIN departments d?
ON (e.department_id = d.department_id);?
等价于?
SELECT e.last_name, e.department_id, d.department_name?
FROM employees e, departments d?
WHERE e.department_id=d.department_id(+)?
结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。?

RIGHT OUTER JOIN:右外关联?
SELECT e.last_name, e.department_id, d.department_name?
FROM employees e?
RIGHT OUTER JOIN departments d?
ON (e.department_id = d.department_id);?
等价于?
SELECT e.last_name, e.department_id, d.department_name?
FROM employees e, departments d?
WHERE e.department_id(+)=d.department_id?
结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。?

FULL OUTER JOIN:全外关联?
SELECT e.last_name, e.department_id, d.department_name?
FROM employees e?
FULL OUTER JOIN departments d?
ON (e.department_id = d.department_id);?
结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。

?

?

?

?

?

?

SQL--JOIN之完全用法 ? ??
? ? ??

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