ORACLE 8i,9i 表连接方法全介绍

原创 2005年05月21日 09:19:00

ORACLE 8i,9i 表连接方法全介绍

本文大部分内容摘自CNOUG网友jaunt的贴子

http://www.cnoug.org/viewthread.php?tid=1174&highlight=%CD%E2%C1%AC%BD%D3

一般的相等连接:
select * from a, b where a.id = b.id;
这个就属于内连接。
  
对于外连接
Oracle中可以使用“(+) ”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN  
  
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的员工记录。  
  
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  
结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。  
  
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的员工记录和没有任何员工的部门记录。

ORACLE8i是不直接支持完全外连接的语法,也就是说不能在左右两个表上同时加上(+),下面是在ORACLE8i可以参考的完全外连接语法
select t1.id,t2.id from table1 t1,table t2 where t1.id=t2.id(+)
union
select t1.id,t2.id from table1 t1,table t2 where t1.id(+)=t2.id

Oracle9i PLSQLT程序设计8

  • 2008年05月10日 14:03
  • 1.32MB
  • 下载

Oracle9i 数据库技术8

  • 2007年11月23日 11:46
  • 560KB
  • 下载

KB-Oracle 9i NVarchar求生守則 之Delphi 解決方法

現在被Oracle 9i的NVarchar的Unicode問題困擾很久了,在網上看到一篇文章KB-Oracle 9i NVarchar求生守則可 以在C#里解決這個問題,我想知道如何在Delphi ...

oracle8i在linux9的安装

  • 2014年03月20日 20:21
  • 8KB
  • 下载

oracle9i中文版基础培训教程8-13

  • 2007年08月29日 17:17
  • 5.76MB
  • 下载

Oracle9i的常见登陆问题的解决方法

近来,浏览BBS时,常看到“急急急!如何启动OMS?”的字眼,就针对以上这类问题,我有些经验想和大家共同分享。 能否正常启动OEM或OMS关键有以下两点: 第一.Oracle的系统服务是否开启; ...
  • ergouge
  • ergouge
  • 2012年05月11日 17:02
  • 862

Oracle8i_9iBasic

  • 2007年09月04日 10:35
  • 3.94MB
  • 下载

SQL2000将数据导入Oracle9i的方法

  • 2010年04月03日 10:30
  • 820KB
  • 下载

[转]Oracle9i的常见登陆问题的解决方法

第一.Oracle的系统服务是否开启;第二.登录时用的用户名和口令是否正确。那么先针对第一点谈谈Oracle的系统服务。在完全安装的情况下,Oracle的系统服务共有11项:1.Oracle OLAP...

oracle9i310安装,连接oracle9,10的方法

  • 2012年12月12日 21:50
  • 12.29MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ORACLE 8i,9i 表连接方法全介绍
举报原因:
原因补充:

(最多只允许输入30个字)