zoukankan      html  css  js  c++  java
  • 如何提高报表sql效率

    1、  能用基表达到目的的,尽量用基表。当然,需要用视图的,如HR模块涉及到权限控制时,必须用视图。

    2、  索引,这个不在赘述。

    3、  汇总的时候,如果是两次汇总,大汇总的字段可以由小汇总字段得出。如集团公司由它的二级部门写函数得出。所在在cursor里,可以只小汇总,如只按二级部门汇总,输出的时候才条件判断来进行大汇总。

    4、  如果主cursor很庞大,可以将其分解成若干个小cursor,多写一些函数,也可以提高效率,分解主cursor

    5、  循环cursor时:避免重复性的基于同值的计算。避免重复性的调用同参数的同函数,可以只计算一次,把结果赋给一个变量。如果是在cursor里,当汇总的时候,也是可以的只计算一次的。

    6、  涉及到大数量时,用unionor效率高。

    7、  分模块写pl/sql代码。有时候我们一段代码很多地方会重复用到,却是实现了相同的模块功能,为了以后维护的方便,直接将其写成一过程,重复调用。

    8、  使用全局变量。当一个值需要通过计算获得时,可以在程序开头就将其计算出来,并将结果赋给一个全局变量,然后在包类重复调用该变量。

    9、  自定义一个标准包。当我们有大量程序要开发时,如果这些程序会调用相同的函数或过程,我们可以将这些函数或程序,放在同一个标准包里,供项目组其他同事共同调用,提高开发效率,维护也方便。

    10、参数及一些能大量减少数据量的WHERE条件,尽量写在WHERE最后边。

    转载 http://wfly2004.blog.163.com/blog/static/117642720105110236847/

  • 相关阅读:
    20201215王馨瑶 实验一《Python程序设计》实验报告
    20201215第十六周学习总结
    python笔记
    信导笔记
    成绩调节
    2020-2021-1 20201226 《信息安全专业导论》第十三周学习总结
    链表(补交)
    2020-2021-1 20201226 《信息安全专业导论》第十二周学习总结
    Wireshark 实践
    ssh
  • 原文地址:https://www.cnblogs.com/future2012lg/p/3025639.html
Copyright © 2011-2022 走看看