oracle多表联查的优化方案,ORACLE多表查询优化

本文探讨了ORACLE数据库中多表查询的性能优化,强调了执行路径优化的重要性。通过调整init.ora参数,增大高速缓冲区,提高SQL语句的共享率,可以显著提升查询效率。此外,详细介绍了SQL语句必须完全一致(包括空格和换行)才能共享,以及共享的三个条件。还提及了建立表空间的操作和如何在Oracle数据库之间进行数据迁移。
摘要由CSDN通过智能技术生成

ORACLE多表查询优化

转自某地,对作者很愧疚- -!不晓得地址了..

ORACLE多表查询优化

这里提供的是执行性能的优化,而不是后台数据库优化器资料:

参考数据库开发性能方面的各种问题,收集了一些优化方案统计如下(当然,象索引等优化方案太过简单就不列入了,嘿嘿):

执行路径:ORACLE的这个功能大大地提高了SQL的执行性能并节省了内存的使用:我们发现,单表数据的统计比多表统计的速度完全是两个概念.单表统计可能只要0.02秒,但是2张表联合统计就可能要几十表了.这是因为ORACLE只对简单的表提供高速缓冲(cache buffering) ,这个功能并不适用于多表连接查询..数据库管理员必须在init.ora中为这个区域设置合适的参数,当这个内存区域越大,就可以保留更多的语句,当然被共享的可能性也就越大了.

当你向ORACLE提交一个SQL语句,ORACLE会首先在这块内存中查找相同的语句.

这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须

完全相同(包括空格,换行等).

共享的语句必须满足三个条件:

A.       字符级的比较:

当前被执行的语句和共享池中的语句必须完全相同.

例如:

SELECT * from EMP;

和下列每一个都不同

SELECT * from EMP;

Select * from Emp;

SELECT       *      from EMP;

B.       两个语句所指的对象必须完全相同:

用户对象名                       如何访问

Jack   sal_limit                      private synonym

Work_city                    &nbs

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值