对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存储过程的开发的介绍

当前文章:对Oracle表查询优化问题的研究
网页链接:http://www.shufengxianlan.com/qtweb/news1/293651.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联