ITPub博客

首页 > 数据库 > Oracle > oracle中的外连接简单介绍

oracle中的外连接简单介绍

原创 Oracle 作者:moonsoft 时间:2019-04-25 22:42:05 0 删除 编辑
先要弄明白什么是外连接, 就是当一个表中的数据和另一个表里的数据(行)或多或少不相等,当连接两个表的时候,其中一些数据查不出来,这时候要想到使用外连接--理性的浪漫[@more@]

oracle中的外连接简单介绍

在讲外连接之前,先举例介绍内连接,也就是一般的相等连接。

select * from a, b where a.id = b.id;

对于外连接,oracle中可以使用“(+)”来表示,9i可以使<-- copyright 1999-2000 thruport technologies http://www.thruport.com --><-- end dynamic banner insert -->用left/right/full outer join,下面将配合实例一一介绍。

1. 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的员工记录。

2. 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;


结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。

3. 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的员工记录和没有任何员工的部门记录。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/226700/viewspace-828337/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2005-01-20

  • 博文量
    412
  • 访问量
    332352