Oracle中的左右连接

在Oracle中左右连接省去了sql server中复杂的连接语句(left join ,right join),就用一个(+)表示。 下面做了下实验:其中查询1

在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,(+)放在包含空值的一边,不可以两边同时使用。
 

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1895015.html

(0)
上一篇 2025年2月22日 13:48:11
下一篇 2025年2月22日 13:48:28

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • oracle连接SQLserver–通过ODBC实例

    我是按照上面的链接来操作的,成功了,但是在同一个服务器上面操作的(即sqlserver,oracle是在同一机器上,不同机器待实验,都是32位机)。 我是按照上面的链接来操作的,成功了,但是在同一个服务器上面操作的(即sqlserver,o…

    数据库 2025年2月21日
    200

发表回复

登录后才能评论