首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

oracle中的上下连接

2013-04-09 
oracle中的左右连接在oracle中左右连接省去了sql server中复杂的连接语句(left join ,right join),就用一

oracle中的左右连接

在oracle中左右连接省去了sql server中复杂的连接语句(left join ,right join),就用一个"(+)"表示。
下面做了下实验:其中查询1和查询2是等同效果的,查询3和查询4是等同效果的。

查询1:
select first_name,department_name,emp.department_id from emp,departments dept
where emp.department_id(+)=dept.department_id;

122 rows selected.

查询2:
select first_name,department_name,emp.department_id from departments dept left join emp
on emp.department_id=dept.department_id;

122 rows selected.

 

 

查询3:
select first_name,department_name,emp.department_id from emp,departments dept
where emp.department_id=dept.department_id(+);

107 rows selected.

查询4:
select first_name,department_name,emp.department_id from  emp  left join departments dept
on emp.department_id=dept.department_id;

107 rows selected.

 

总结:

1,(+)在哪一边,则返回另一边所有的记录。

2,(+)放在包含空值的一边,不可以两边同时使用。

 

热点排行