资讯

顺景动态

以前瞻视觉
发现并布局未来
当前位置:首页 > 资讯 > 常见问答

你知道在erp系统中设计复杂报表的注意事项吗?

2020-04-25   618

  在erp系统中,从原则上是禁止设计超过两个模块的数据报表,最好是将报表的范围限制在单个模块下。如此的话,无论从性能还是从数据的准确性上都会有所保障。但是,如果用户确实有需要实现比较复杂的报表,在这种情况下,该如何处理呢?我们应该注意什么呢?接下来由台湾erp公司为大家进行简单地介绍吧。


  1.使用固化视图来改善数据库的性能。


  复杂报表所导致的不利影响,首当其冲的是报表查询时速度会很慢,性能很低。为此在涉及到复杂报表时,开发人员可以考虑采用固化视图来改善数据库的性能。如在Oracle数据库中,固化视图又叫做物化视图。通过固化视图,可以预先计算并保存报表连接或者聚集等耗时比较多的操作结果。简单的说,就将某个报表的查询结果存储在一张单独的表中。如此的话,在执行查询时,就可以避免使用这些耗时的操作,同时减少磁盘的冲突,从而以最短的时间得到用户想要的结果。一般来说,固化视图对于复杂的报表来说,能够提供三方面的作用。如可以提高查询的性能。如固化视图对于应用来说是透明的,增加和删除物化视图不会影响应用程序中SQL语句的正确性和有效性。但当基表发生变化时,物化视图也会同时更新。不过需要注意的是,物化视图也会带来一些负面影响。如物化视图的数据会保存在硬盘中,为此就会占用额外的存储空间等。总之,在设计比较复杂的报表时,开发人员可以与数据库工程师商量,如果可以的话,需要尽量采用固化视图。


timg (1).jpg


  2.复杂的报表当涉及到多表时,最好采用模块化的设计。


  如某视图,其涉及到的基表有近20张。那么在设计视图时,要避免将其放在一个SQL语句中。而应该借鉴应用程序的模块化设计,将其设计成不同层次的视图,然后再进行连接查询。如上面这个案例,至少可以将其分为四层。最基层是基本数据表,第二层是零件出库信息、当月采购信息等数据,第三层是根据第二层的数据进行计算分析;第三层视图再将这些视图进行连接。这么操作的话,方便后续的维护与查询。同时也可以提高查询的速度。如在第二层视图设计中,可以对基础表的数据进行过滤。此时由于基础数据少,那么后续的报表查询速度也会加快。为此对于比较复杂的报表设计,要考虑分层设计的思路,以提高报表的查询性能与灵活性。沟通工具


  以上便是在erp系统中设计复杂报表的注意事项,希望能够对大家有所八周年过户。其实比较繁琐的报表视图,原则上仍是少弄为妙。由于其在功能或数据的准确性上都很难掌控的。假如真的要树立繁琐视图,那么在规划与开发时,参谋需要听取数据库工程师的意见,思考嵌入数据的查询功能,并采纳办法提高数据的准确性。