ORACLE多表查询优化

ORACLE多表查询优化

ID:47326943

大小:24.40 KB

页数:7页

时间:2020-01-10

ORACLE多表查询优化_第页
预览图正在加载中,预计需要20秒,请耐心等待
资源描述:

《ORACLE多表查询优化》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、.ORACLE多表查询优化时间:2009-10-2913:34:35来源:网络作者:未知点击:156次ORACLE多表查询优化这里提供的是执行性能的优化,而不是后台数据库优化器资料:参考数据库开发性能方面的各种问题,收集了一些优化方案统计如下(当然,象索引等优化方案太过简单就不列入了,嘿嘿):执行路径:ORACLE的这个功能大大地提高了SQL的执行性能并节省了内存的使用:我们发现,单表数据的统计比多表统计的速度完全是两个概念.单表统计可能只要0.02秒,但是2张表联合统计就可能要几十表了.这是因为ORACLE只对简单的表提供高速缓冲(cachebu

2、ffering),这个功能并不适用于多表连接查询..数据库管理员必须在init.ora中为这个区域设置合适的参数,当这个内存区域越大,就可以保留更多的语句,当然被共享的可能性也就越大了.当你向ORACLE提交一个SQL语句,ORACLE会首先在这块内存中查找相同的语句.这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须完全相同(包括空格,换行等).     共享的语句必须满足三个条件:A.      字符级的比较:当前被执行的语句和共享池中的语句必须完全相同.      例如:          SELECT*FR

3、OMEMP;      和下列每一个都不同          SELECT*fromEMP;          Select*FromEmp;          SELECT      *     FROMEMP;B.      两个语句所指的对象必须完全相同:  用户对象名                      如何访问Jack  sal_limit                     privatesynonymWork_city                          publicsynonymPlant_detail   

4、                     publicsynonymJillsal_limit                        privatesynonymWork_city                          publicsynonymPlant_detail                       tableowner     考虑一下下列SQL语句能否在这两个用户之间共享.SQL能否共享原因selectmax(sal_cap)fromsal_limit;不能每个用户都有一个privatesynonym-sal_

5、limit,它们是不同的对象selectcount(*)fromwork_citywheresdesclike'NEW%';能两个用户访问相同的对象publicsynonym-work_cityselecta.sdesc,b.locationfromwork_citya,plant_detailbwherea.city_id=b.city_id不能用户jack通过privatesynonym访问plant_detail而jill是表的所有者,对象不同.C.      两个SQL语句中必须使用相同的名字的绑定变量(bindvariables)..例如

6、:第一组的两个SQL语句是相同的(可以共享),而第二组中的两个语句是不同的(即使在运行时,赋于不同的绑定变量相同的值)a.selectpin,namefrompeoplewherepin=:blk1.pin;selectpin,namefrompeoplewherepin=:blk1.pin;b.selectpin,namefrompeoplewherepin=:blk1.ot_ind;selectpin,namefrompeoplewherepin=:blk1.ov_ind;重点关注1:选择最有效率的表名顺序(只在基于规则的优化器中有效)重点关注

7、ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,因此FROM子句中写在最后的表(基础表drivingtable)将被最先处理.在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表.当ORACLE处理多个表时,会运用排序及合并的方式连接它们.首先,扫描第一个表(FROM子句中最后的那个表)并对记录进行派序,然后扫描第二个表(FROM子句中最后第二个表),最后将所有从第二个表中检索出的记录与第一个表中合适记录进行合并.例如:      表TAB116,384条记录         表TAB21      条记录   

8、  选择TAB2作为基础表(最好的方法)     selectcount(*)fromtab1,tab2   执行时间0.

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。