Oracle中怎么优化复杂视图

Oracle中怎么优化复杂视图,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

成都网站建设、做网站的开发,更需要了解用户,从用户角度来建设网站,获得较好的用户体验。成都创新互联公司多年互联网经验,见的多,沟通容易、能帮助客户提出的运营建议。作为成都一家网络公司,打造的就是网站建设产品直销的概念。选择成都创新互联公司,不只是建站,我们把建站作为产品,不断的更新、完善,让每位来访用户感受到浩方产品的价值服务。

优化方法

如果可以将这类视图中常用的谓词条件直接写入视图内,且写成动态的,同时将常用查询列按选择性由大至小创建组合索引,则优化器可以尽可能地使用索引直接获取数据,再进行过滤计算等操作,以此达到优化目的。具体操作步骤如下:

(1)创建一个辅助包,并创建两个函数,实际情况中若同时传入多个条件可自行扩充包中方法,每一个条件需要增加两个方法。

(2)修改视图定义,将谓词条件写入至基表条件中,并重新编译视图。

性能对比

下面通过具体的例子来说明如何对复杂视图进行优化。

通过将原视图和优化后视图进行对比,看出优化后视图的执行计划成本由349降到86,优化效果非常明显。表中红框部分内容需特别引起注意。

优化前视图查询的执行计划是全表扫描,执行效率低下。优化后视图查询的执行计划是索引范围扫描。通过索引直接取出需要访问的数据,再进行后续处理,性能较优化前有大幅提升。

需要指出的是,该方法只在访问视图中少量数据时效果明显,如果访问数据量大,该方法不适用。

表4.1 优化前视图定义、查询语句及执行计划

Oracle中怎么优化复杂视图

表4.2 优化后视图定义、查询语句及执行计划

Oracle中怎么优化复杂视图

通过以上分析对比可以清晰地看出,优化后的视图可以使用索引且性能有了显著提高。总结起来,对于复杂查询优化思路应该是:如果视图中访问的是少量数据,则尽可能通过索引先取出需要处理的数据,然后再进行后续处理。此方法适用的前提是,复杂视图使用各种常规优化方法(如增加索引,添加提示符等)都无效时。

但是,这一方法也有一定弊端,那就是与其它优化方法相比,此法需要做的前期工作较多,如建立辅助包,对原视图进行修改和重新编译。另外还需测试优化前后查询结果是否一致,查询前需调用辅助包,将查询条件传入视图中,不过优化后的视图是不需要加查询条件的。

看完上述内容,你们掌握Oracle中怎么优化复杂视图的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


名称栏目:Oracle中怎么优化复杂视图
分享链接:http://azwzsj.com/article/giopgp.html