润乾报表分页标签中totalCountExp的几种用法

海量数据的清单式列表在读取、展现及导出过程中可能会出现速度过慢、内存溢出、系统死机等问题,以分页计算方式发布报表,可以实现以页为单位对数据进行读取和展现及导出等操作,大大降低内存占有量,提高了运行效率,避免内存溢出等问题。

在分页标签中的totalCountExp属性,是代表总记录数,为必填属性,分页就是基于这个总记录数来的。它的值是一个润乾的非数据集函数,并且返回的值应该是一个整型数据。

下面就来介绍一下totalCountExp的几种用法:

1.直接写整数:

这种方式对于固定的总记录数来说,非常方便简单.

        <report:extHtml

        name="report1"

        reportFileName="api/1.6.raq"   //报表名,必填属性

        totalCountExp="10000"   //总记录数,必填属性

        />

但此用法比较少见,因为总记录数一般都是动态查询出来的.

2.query一个sql,得到总记录数:

        <report:extHtml

        name="report1"

        reportFileName="api/1.6.raq"   //报表名,必填属性

        totalCountExp="query('SELECTcount(*) FROM 订单明细')"  //query执行一个count的sql。

        />

这种用法是最常见的,如果query的sql要动态生成,还可以这样做:

        <report:extHtml           name="report1"          reportFileName="api/1.6.raq"  //报表名,必填属性          totalCountExp="<%=querySql%>"//query执行一个count的sql。         /> 然后在用代码把querySql拼接上即可.

3.call一个存储过程,得到总记录数:

        <report:extHtml         name="report1"         reportFileName="api/1.6.raq"  //报表名,必填属性         totalCountExp="call('{callRQ_TEST_CUR(?)} ','@@result')"   //call执行一个count的存储过程。         /> 此用法比较特殊,由于存储过程的特性,我们可以在存储过程里完成复杂的逻辑运算传参等,然后查询出需要的总记录数.上面的用法针对oracle数据库存储过程的方法,其他数据库的写法大致相同.

其中:RQ_TEST_CUR(?)为存储过程的名字,?代表输出参数(游标类型),后面的@@result与?进行绑定.

4.从报表模版中的数据集中读取已建立好的数据集sql,当作总记录数.

第一步,从报表模版里获取sql

import com.runqian.report4.model.ReportDefine;

import com.runqian.report4.usermodel.DataSetConfig;

import com.runqian.report4.usermodel.SQLDataSetConfig;

import com.runqian.report4.util.ReportUtils;

public class sqlReadOut {

/**

 * @param args

 * @throws Exception 

 */

public static void main(String[] args) throws Exception {

// TODO Auto-generated method stub

        ReportDefine rd = (ReportDefine)ReportUtils.read("C:\\Program Files\\reportHome\\webapps\\demo\\reportFiles\\初级教程\\3.3.raq");

        SQLDataSetConfig sdc = (SQLDataSetConfig)rd.getDataSetMetaData().getDataSetConfig(1);

        String sql = sdc.getSQL();

        System.out.println(sql);

}

}

第二步,把这个sql根据第2种办法赋值给标签.

以上就是分页标签中totalCountExp的几种用法,通过润乾丰富的API和页面处理,还可以组合出更多样的方法.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值