理解oracle中外连接.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
两个表: A(id,name) 数据:(1,张三)(2,李四)(3,王五) B(id,name) 数据:(1,学生)(2,老师)(4,校长) 左连接结果: select A.*,B.* from A left join B on A.id=B.id; 1 张三 1 学生 2 李四 2 老师 3 王五 NULL NULL 右链接结果: select A.*,B.* from A right join B on A.id=B.id; 1 张三 1 学生 2 李四 2 老师 NULL NULL 4 校长 **************** 补充:下面这种情况就会用到外连接 比如有两个表一个是用户表,一个是交易记录表,如果我要查询每个用户的交易记录就要用到左外外连接,因为不是每个用户都有交易记录。 用到左外连接后,有交易记录的信息就会显示,没有的就显示NULL,就像上面我举得例子一样。 如果不用外连接的话,比如【王五】没有交易记录的话,那么用户表里的【王五】的信息就不会显示,就失去了查询所有用户交易记录的意义了。 **************** 看一下结果就能明白左右连接的区别了。 左外连接中左边的表。 右外连接中右边的表。 全外连接中全部的表。 替换 NULL 的表: 左外连接中右边的表 右外连接中左边的表 全外连接中全部的表 在全外连接中,两张表既可以保留行,也可以替换 NULL。 当不存在匹配的行时,替换 NULL 的表替换 NULL。如果连接操作中不存在匹配,任何在 SELECT 列中引用的替换 NULL 表的列都将替换为NULL。 外连接的处理 1 取出外连接的两个表: d,e 见图1,2 2 取出满足连接条件的所有行,加上保留行表中所有不满足连接条件的行, 不满足连接条件的行的组成: 保留行表中的列保留原值,替换 NULL 的表中的列都将包含 NULL。 3 几种特殊情况 a 见图3,4 where d.deptno(+)=10 无保留行表 where d.deptno(+)=70 无保留行表 b. 见图5,6 where d.deptno(+)=e.deptno and e.deptno(+)=10 == where d.deptno=e.deptno and e.deptno=10 c. 见图7,8 where d.deptno(+)=e.deptno and d.deptno(+)=10 == d right join e on (d.deptno=e.deptno and d.deptno=10) d. 见图9,10 where d.deptno(+)=e.deptno and d.deptno=10 == d right join e on d.deptno=e.deptno where d.deptno=10 附d 的 sql代码 select D.DEPTNO as ddeptno, D.DNAME, E.EMPNO, E.DEPTNO, E.ENAME, e.deptno as edeptno from scott.D d , scott. E e where d.deptno(+)=e.deptno and d.deptno=10 select D.DEPTNO as ddeptno, D.DNAME, E.EMPNO, E.DEPTNO, E.ENAME, e.deptno as edeptno from scott.D d right join scott. E e on d.deptno =e.deptno where d.deptno=10 图表 1 图表 2 图表 3 图表 4 图表 5 图表 6 图表 7 图表 8 图表 9 图表 10

文档评论(0)

wx171113 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档