Oracle 左连接与右连接

 在Oracle PL-SQL中,左连接和右连接可以用如下的方式实现:

  语句片断:

  SELECT emp_name, dept_name

  FORM Employee, Department

  WHERE Employee.emp_deptid(+) = Department.deptid此SQL文使用了右连接,即“(+)”所在位置的另一侧为连接的方向,右连接说明等号右侧的所有记录均会被显示,无论其在左侧是否得到匹配,也就是说上例中无论会不会出现某个部门没有一个员工的情况,这个部门的名字都会在查询结果中出现。

  相反的情况:

  SELECT emp_name, dept_name

  FORM Employee, Department

  WHERE Employee.emp_deptid = Department.deptid(+)则是左连接,无论这个员工有没有一个能在Department表中得到匹配的部门号,这个员工的记录都将被显示。

 

 

外连接 ,条件不能使子查询,

比如:

 

SELECT A.ID, B.ID, A.ATTRIBUTE, B.ATTRIBUTE

FROM TABLE_A A

JOIN TABLE_B B

ON A.ID(+) = B.ID

AND A.VALUE(+) = (SELECT VALUE FROM TABLE_C WHERE C.ID = 1)

 

 

应该改成,

 

 

SELECT *

FROM (

SELECT A.ID AS "A_ID",

B.ID AS "B_ID",

A.ATTRIBUTE AS "A_ATTRIBUTE",

B.ATTRIBUTE AS "B_ATTRIBUTE"

FROM TABLE_A A

JOIN TABLE_B B

ON A.ID(+) = B.ID) TEMP

WHERE AND TEMP.A_ATTRIBUTE = (SELECT VALUE FROM TABLE_C WHERE C.ID = 1)

 

 

 

你可能感兴趣的:(oracle,sql,table)