Oracle 外连接和 (+)号的用法 【转载】 对于外连接,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 code SQL> desc part Name Null? Type ----------------------------------------- -------- ----------------- PART_ID NOT NULL VARCHAR2(4) SUPPLIER_ID VARCHAR2(4)SQL> select * from part;PART SUPP---- ----P1 S1P2 S2P3P4SQL> 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#1S2 Supplier#2S3 Supplier#3SQL> select p.part_id, s.supplier_name 2 from part p, supplier s 3 where p.supplier_id = s.supplier_id (+);PART SUPPLIER_NAME---- --------------------P1 Supplier#1P2 Supplier#2P3P4--(+)是单向的SQL> select p.part_id, s.supplier_name 2 from part p, supplier s 3 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_name 2 from part p, supplier s 3 where p.supplier_id = s.supplier_id (+) 4 union 5 select p.part_id, s.supplier_name 6 from part p, supplier s 7 where p.supplier_id (+) = s.supplier_id;PART SUPPLIER_NAME---- --------------------P1 Supplier#1P2 Supplier#2P3P4 Supplier#3--现在的语法 SQL> select p.part_id, s.supplier_name 2 from part p full outer join supplier s 3 on p.supplier_id = s.supplier_id;PART SUPPLIER_NAME---- --------------------P1 Supplier#1P2 Supplier#2P4P3 Supplier#3另外的EG: SQL codeSQL> select * from testa; ID NAME ADDR AGE---------- ------ ------ ---------- 3 电子 南京 23 5 物理 北京 23 6 物理 河北 25 1 电脑 上海 23 2 电子 北京 22 4 物理 芜湖 22 7 艺术 上海 21 8 歌剧 苏州 16 9 沈亮 上海 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 andtesta.addr(+)=testb.addr; ID ADDR---------- ------ 7 上海 现在的Outer Join方法是Oracle9i时开始引用的 ANSI标准的联接语法,现在的则比较直观 简单 通过上边Full Join的实现方式 不难看到ANSI的联接语法要比用含Union的(+)的执行效率更高~~ 更详细的解释 请阅读Oracle原版ENGLISH VERSION HELP
- 浏览: 274612 次
- 来自: 云南大理
最新评论
-
showzh:
...
Oracle中如何插入特殊字符:& 和 ' (多种解决方案) -
tarena_hhh:
fcm915 写道那个 双击选中一个字段,其他相同的也全变色 ...
eclipse的快捷键 -
summer_java:
培训兴趣很重要。。呵呵,学习过程还需要脚踏实地,非常喜欢这篇文 ...
JAVA学习路线 -
metadmin:
多学多连,更要勤思考。思考这是第一位的,这样才有自己的创新。我 ...
JAVA学习路线 -
nannancya:
我想下载oracle11g,点了accept licences ...
oracle&&Weblogic下载
相关推荐
- **传输方式**:选择合适的传输方法,例如通过归档日志或直接使用网络传输等方式。 - **传输频率**:根据业务需求设定重做日志条目的传输频率。 #### 七、故障切换与计划内切换 - **故障切换(Failover)**:当...
三、以下列出了在使用JDBC来连接Oracle数据库时可以使用的一些技巧,这些技巧能够使我们更好地发挥系统的性能和实现更多的功能(系转载)。 1、在客户端软件开发中使用Thin驱动程序 在开发Java软件方面,Oracle...
3. **优化应用**:减少不必要的并发连接,优化应用程序以减少长连接时间,或者使用连接池来复用已存在的进程。 4. **监控与预警**:设置监控脚本或使用管理工具实时监控进程使用情况,一旦接近最大值,提前采取措施...
<br>使用方法: (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。...
本文讨论了如何使用SQL语句和DOS命令来导入.dmp文件中的Oracle数据库内容,包括更改数据库管理员密码、创建表空间、创建用户、用户授权以及如何在命令提示符(cmd)下运行导入命令。 首先,更改数据库管理员sys/...
使用方法: (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。 (4)部署到...
常用的是通过JVM进程ID连接,使用`./as.sh --port 3658 --telnet`命令,然后在另一个终端窗口中使用`telnet localhost 3658`,输入进程ID连接。 三、主要命令介绍 1. `help`:显示所有可用的命令。 2. `asciitable...
通过这个综合实例,你不仅能学习到如何在VBA中设置数据源连接,执行SQL查询,还能掌握处理结果集、进行数据操作的方法。实践这些步骤,将增强你在Excel办公自动化中的能力,尤其是处理大量数据时,能够显著提高效率...
使用方法: (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。 (4)部署到tomcat服务器中...
文件标题和描述中提到的“SQL语句大全”指的是一个包含多种SQL命令和用法的集合,旨在为数据库用户和开发者提供全面的参考资料。这个大全可能包括了数据定义语言(DDL)、数据操纵语言(DML)、数据查询语言(DQL)...
5. **数据库连接**:了解如何配置和使用ADO,建立与数据库的连接,执行SQL查询,以及数据绑定到控件。 6. **记录集操作**:掌握TDataSet、TDataSource、TDBGrid等组件的用法,进行数据的增删改查操作。 7. **事务...
******************************* ... 欢迎转载,但请保留出处,谢谢 ******************************* 很久没有发布东东了,今天看到盒子上有朋友发布了个三层的东东, ...具体使用方法可以查看DEMO程序
《GDAL源码剖析》这一系列文章意在系统地介绍GDAL的使用方法、内部结构和算法原理。由于作者是在Windows平台上使用GDAL,因此本系列文章不涉及Linux平台下的内容。如果用户对GDAL在Linux平台上的应用感兴趣,需要...
设计模式之 Template(模板方法) 实际上向你介绍了为什么要使用 Java 抽象类,该模式原理简单,使用很普遍. 设计模式之 Strategy(策略) 不同算法各自封装,用户端可随意挑选需要的算法. 设计模式之 Chain of ...
其实还有更简单的方法,而且是更好的方法,使用合理描述参数和SQL语句返回值的接口(比如IUserOperation.class),这样现在就可以至此那个更简单,更安全的代码,没有容易发生的字符串文字和转换的错误.下面是详细...