设为首页 收藏本站
查看: 589|回复: 0

[经验分享] Oracle 外链接 内链接 等

[复制链接]

尚未签到

发表于 2016-8-9 06:24:13 | 显示全部楼层 |阅读模式
首先创建两张表,初始化数据
SQL> create table zk_test_1(id int,name varchar(10));
SQL> insert into zk_test_1 values(1,'aaa');
SQL> insert into zk_test_1 values(2,'bbb');
SQL> insert into zk_test_1 values(3,'ccc');

SQL> create table zk_test_2(id int , score int);
SQL> insert into zk_test_2 values(1,10);
SQL> insert into zk_test_2 values(2,20);
SQL> insert into zk_test_2 values(4,40);

1.内连接(Inner Join): 两表都满足的组合
SQL> select * from zk_test_1 a inner join zk_test_2 b on a.id = b.id;
结果:
ID  NAME  SCORE
1    aaa    10
2    bbb    20

2.外连接(Outter Join):
*左外连接(Left Outer Jion)
左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。其中outer可以忽略。
SQL> select a.id,a.name,b.score from zk_test_1 a left outer join zk_test_2 b on a.id = b.id;
结果:
ID  NAME  SCORE
1    aaa    10
2    bbb    20
3    ccc  (null)

*右外连接(Right Outer Join)
SQL> select a.id,a.name,b.score from zk_test_1 a right outer join zk_test_2 b on a.id = b.id;
结果:
ID  NAME  SCORE
1    aaa    10
2    bbb    20
4   (null)  40

*全外连接(Full Outer Join)
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
SQL> select a.id,a.name,b.score from zk_test_1 a full outer join zk_test_2 b on a.id = b.id;
结果:
ID  NAME  SCORE
1    aaa    10
2    bbb    20
3    ccc  (null)
4   (null)  40

3.外连接与条件配合使用
当在内连接查询中加入条件是,无论是将它加入到join子句,还是加入到where子句,其效果是完全一样的,但对于外连接情况就不同了。当把条件加入到join子句时,SQL Server、Informix会返回外连接表的全部行,然后使用指定的条件返回第二个表的行。如果将条件放到where子句中,SQL Server将会首先进行连接操作,然后使用where子句对连接后的行进行筛选。
在join子句中:
SQL> select a.id,a.name,b.score from zk_test_1 a right join zk_test_2 b on a.id = b.id and b.id = 2;
结果:
ID     NAME     SCORE
(null) (null)   10
2       bbb     20
(null) (null)   40

在where子句中:
SQL> select a.id,a.name,b.score from zk_test_1 a right join zk_test_2 b on a.id = b.id where b.id = 2;
结果:
ID     NAME     SCORE
2       bbb     20

4,自身连接
自身连接是指同一个表自己与自己进行连接。这种一元连接通常用于从自反关系(也称作递归关系)中抽取数据。例如人力资源数据库中雇员与老板的关系。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-254922-1-1.html 上篇帖子: oracle的批量删除数据表记录 下篇帖子: Oracle Sqlplus查询结果导出成Excel
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表