日期:2013-12-31  浏览次数:20500 次


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公式列放在占位列的前面。实际上这里是将占位列作为变量来使用,方便了编程和维护。