一直很晕,不太明白
最后结合例子讲一下
谢谢

解决方案 »

  1.   

    假设有
    a表
    id
    1
    2
    3
    4b表
    id
    1
    2
    3希望出来结果a.id  b.id
    1      1
    2      2
    3      3
    4用left join 的select a.id,b.id
       form a left jion b on a.id=b.id用(+)的
    select a.id,b.id
       form a ,b 
       where  a.id=b.id(+)用(+)的语法简洁,容易读懂,但只是ORACLE支持,LEFT JOIN是通用的,其它没有差别
      

  2.   

    select * from a, b where a.id = b.id;     对于外连接,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的员工记录和没有任何员工的部门记录。
      

  3.   

    看此贴,基本一样的问题
    http://topic.csdn.net/u/20080702/19/7951177e-3ba2-4fbd-a4c9-3cbcf0339857.html
      

  4.   

    left outer join
    right outer join
    就不会晕了。
      

  5.   

      外连接:
      除了显示匹配相等连接条件的数据外,还可以显示某一个表中无法匹配相等连接条件的记录!
      ------------------------------------------------
      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;
      

  6.   

    转帖
    select * from a, b where a.id = b.id;    对于外连接,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的员工记录和没有任何员工的部门记录。