对Oracle表查询优化问题的研究

数据库 Oracle
我们今天主要描述Oracle表查询优化问题的研究,愿在你在学习Oracle表查询优化问题的研究中以起到抛砖引玉的作用。

以下的文章主要是对Oracle表查询优化问题的研究,本文以三个相关的表,即表A,表B ,表C,来作演示,你可以通过以下的文章对其的实际应用与功能有所了解,以下是文章的具体介绍,望你浏览完以下的内容会有所收获。

有表A,2000多行

表B,15w行

表C,18W行

数据库为Oracle9I。

现以表A连接表B,表B连接表C做查询,但经过分析,Oracle始终计划是表A与C产生MERGE JOIN,要知道A表和C表是没有关联的,只能产生笛卡尔集。这样就会产生2000×180000条记录,导致查询性能大大降低,临时表巨大。

请问有什么好办法,使表A先连接表B之后再去连接表C,或者B先连接C之后再连接A都可以。

注:连接字段都建有独立索引。

语句如下:

 

  1. SELECT A.*  
  2. FROM A ,B,C  
  3. WHERE A.COL_A = B.COL_B1 AND B.COL_B2 = C.COL_C  
  4. SELECT A.*  
  5. FROM A JOIN (B JOIN C ON (B.COL_B2 = C.COL_C)) ON (A.COL_A = B.COL_B1)  
  6. SELECT A.*  
  7. FROM (A JOIN B ON A.COL_A = B.COL_B1) JOIN C ON B.COL_B2 = C.COL_C  

 

上述的相关内容就是对Oracle表查询优化问题的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. 创建Oracle procedure并调用在pl/sql里
  2. Oracle to_char的用法描述
  3. Oracle 多表关联如何更新多个字段
  4. Oracle表列的修改具体步骤介绍
  5. Oracle存储过程的开发的介绍
责任编辑:佚名 来源: 互联网
相关推荐

2010-04-19 14:23:34

Oracle增加表分区

2010-10-29 16:48:30

oracle查询所有表

2010-09-28 15:34:05

SQL表结构

2010-05-07 11:00:25

Oracle多表查询

2010-04-12 17:47:01

Oracle多表查询

2011-07-07 16:26:20

Oracle ObjeASPADO

2010-05-10 10:06:45

Oracle查询表名

2010-10-27 15:34:37

oracle查询

2010-10-27 14:41:45

Oracle查询用户表

2017-09-05 09:02:06

Oraclenot null优化

2011-03-15 14:17:28

Oracle自主访问

2010-04-19 17:09:30

Oracle sql

2010-04-28 17:59:19

Oracle表空间

2009-04-24 10:49:57

Oracle性能优化错误

2010-10-21 10:56:29

SQL Server查

2010-10-21 11:10:57

SQL Server查

2010-11-16 16:26:42

Oracle查询用户表

2011-05-20 10:05:13

Oracle性能优化

2010-04-14 13:14:46

Oracle数据库

2011-08-31 13:25:14

点赞
收藏

51CTO技术栈公众号