Report Builder中占位列的使用

Report Builder 中的列类型包括公式列、汇总列、占位列等。一般公式列、汇总列用的比较多,这里不再详述。下面主要讲占位列的一种使用方法。

日前做的应用中,需要 20 个公式列来取值,而每个公式列都使用同样 from 、 where 子句的 sql 语句,唯一区别在于所取的字段不同。这样需要 20 次的读取数据库操作,速度比较慢。一开始考虑再使用一个 query 来做,但是又没有明确的连接关系,无法达到目的。

最后决定研究一下占位列,具体的过程不再赘述,介绍一下实现方法。

1 、首先建立一个公式列, 19 个占位列,分别取名为 CF_1 , CP_2 , CP_3…… , CP_20 。

2 、在公式列的 PL/SQL 中一次将所有值取出:

SELECT COL1,COL2,COL3……COL20

INTO V_COL1,:CP_2,:CP_3……:CP_20

FROM TABLE1

WHERE T_DATE = SYSDATE AND T_DEPT = :P_1;

RETURN V_COL1;

而占位列中不写任何的 PL/SQL 。

3 、在编辑报表页面时,将这些占位列作为域的数据源。

优点:只需要一次数据库读取操作,速度较快。并且由于主要的逻辑均放在 CF_1 那个公式列中,方便维护。

需要注意的是列的顺序,最好将 CF_1 公式列放在占位列的前面。实际上这里是将占位列作为变量来使用,方便了编程和维护。

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus