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

[经验分享] Oracle左右全连接总结

[复制链接]

尚未签到

发表于 2018-9-11 09:54:42 | 显示全部楼层 |阅读模式
  Oracle左右全连接总结
  如何用Oracle RATIO_TO_REPORT计算总数百分比
Oracle 外连接和 (+)号的用法  
  2010-04-18 00:35:07|  分类: Oracle学习笔记|举报|字号 订阅
  转自:http://www.cnblogs.com/iloveu/archive/2009/08/04/1538781.html
  对于外连接,Oracle中可以使用“(+)”来表示,9i可以使用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的员工记录和没有任何员工的部门记录。
  外连接:
  除了显示匹配相等连接条件的数据外,还可以显示某一个表中无法匹配相等连接条件的记录!
  ------------------------------------------------
  1) 左条件(+) = 右条件
  左条件所在的表必须严格进行相等连接条件的匹配,而右条件所在的表除了匹配相等连接条件外,还可以显 示无法匹配连接条件的数据!
  也称为右外连接.
  --------------------------------
  可以用下 列语句取代:
  SELECT...FROM 表1 RIGHT OUTER JOIN 表2 ON 条件;
  2) 左条件 = 右条件(+)
  右条件所在的表必须严格进行相等连接条件的匹配,而左条件所在的表除了匹配相等连接条件外,还可以显示无法匹配连接条件的数据!
  也 称为左外连接.
  --------------------------------
  可以用下列语句取代:
  SELECT...FROM 表1 LEFT OUTER JOIN 表2 ON 条件;
  REM 除了相等连接之外,显示没有员工的部门信息.
  SELECT * FROM EMP,DEPT WHERE EMP.DEPTNO(+) = DEPT.DEPTNO;
  SELECT * FROM EMP RIGHT OUTER JOIN DEPT ON EMP.DEPTNO = DEPT.DEPTNO;
  REM 除了相等连接之外,显示没有部门的员工信息.
  SELECT * FROM EMP,DEPT WHERE EMP.DEPTNO = DEPT.DEPTNO(+);
  SELECT * FROM EMP LEFT OUTER JOIN DEPT ON EMP.DEPTNO = DEPT.DEPTNO;
  Oracle 建议你用在From语句后用Outer Join语法 而不是Oracle的Join操作符(+).而且(+)是要受下面的规则限制的,但Outer Join语法则不受的~~
  1)你不可以 在查询块中使用(+) 当它同时包含 join的from语句中
  2)(+)只是在where语句中,并且只能对应一个表或视图的一行字段
  3) 如果A和B做联接时有多个条件,那么(+)必须完善所有的匹配条件,
  如果没有 ,oracle不会警告你~只是结果自然不同的
  4)不 可以在作出一个表外查询 另张表内查询的(+)联接操作~~
  5)不可以用(+)外联接到自己 当然Self Join是可以的
  6)含 (+)的Where后的注意
  OR不可用
  IN不可用
  子查询不可用
  以下给些个例子:

  •   SQL co
      de
  • SQL> desc part  Name
    Null?    Type----------------------------------------- -------- ----------------- PART_ID                                   NOT NULL VARCHAR2(4)  SUPPLIER_ID
    VARCHAR2(4)  SQL
    > select * from part;  PART SUPP
    ---- ----P1   S1  P2   S2
      P3
      P4
      SQL
    > desc supplier  Name
    Null?    Type----------------------------------------- -------- ----------------- SUPPLIER_ID                               NOT NULL VARCHAR2(4)  SUPPLIER_NAME
    NOT NULL VARCHAR2(20)  SQL
    > select * from supplier;  SUPP SUPPLIER_NAME
    ---- --------------------S1   Supplier#1  S2   Supplier#
    2  S3   Supplier#
    3  SQL
    > select p.part_id, s.supplier_name2  from part p, supplier s3  where p.supplier_id = s.supplier_id (+);  PART SUPPLIER_NAME
    ---- --------------------P1   Supplier#1  P2   Supplier#
    2  P3
      P4
    --(+)是单向的  SQL
    > select p.part_id, s.supplier_name2  from part p, supplier s3  where p.supplier_id (+) = s.supplier_id (+);where p.supplier_id (+) = s.supplier_id (+)*  ERROR at line
    3:  ORA
    -01468: a predicate may reference only one outer-joined table--实现Full Join的方法  SQL
    > select p.part_id, s.supplier_name2  from part p, supplier s3  where p.supplier_id = s.supplier_id (+)4  union5  select p.part_id, s.supplier_name6  from part p, supplier s7  where p.supplier_id (+) = s.supplier_id;  PART SUPPLIER_NAME
    ---- --------------------P1   Supplier#1  P2   Supplier#
    2  P3
      P4
      Supplier#
    3--现在的语法SQL> select p.part_id, s.supplier_name2  from part p full outer join supplier s3  on p.supplier_id = s.supplier_id;  PART SUPPLIER_NAME
    ---- --------------------P1   Supplier#1  P2   Supplier#
    2  P4
      P3
      Supplier#
    3  另外的EG:
      SQL code
      SQL
    > select * from testa;  ID NAME  ADDR         AGE
    ---------- ------ ------ ----------         3 电子   南京           235 物理   北京           236 物理   河北           251 电脑   上海           232 电子   北京           224 物理   芜湖           227 艺术   上海           218 歌剧   苏州           169 沈亮   上海           22  已选择9行。
      SQL
    > select * from testb;  ID ADDR
    ---------- ----------        7 上海1 北京3 上海5 合肥--匹配完全select testa.id,testa.addr from testa,testb where testa.id(+)=testb.id and  testa.addr(
    +)=testb.addr;  ID ADDR
    ---------- ------         7 上海



运维网声明 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.iyunv.com/thread-571819-1-1.html 上篇帖子: oracle更改编码 下篇帖子: oracle sys用户和system用户
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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