1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

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

2022-11-26 | 数据库 | admin | 583°c
A+ A-

以下的文章主要是对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都可以。

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

语句如下:

SELECTA.* 
FROMA,B,C 
WHEREA.COL_A=B.COL_B1ANDB.COL_B2=C.COL_C 
SELECTA.* 
FROMAJOIN(BJOINCON(B.COL_B2=C.COL_C))ON(A.COL_A=B.COL_B1) 
SELECTA.* 
FROM(AJOINBONA.COL_A=B.COL_B1)JOINCONB.COL_B2=C.COL_C 

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11719.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。