欢迎来到天天文库
浏览记录
ID:38796070
大小:647.34 KB
页数:22页
时间:2019-06-19
《关于润乾报表的补充说明》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、分页说明:为方便大家开发,本人在工资系统中作出一个DEMO,经过测试后能正常使用。先将部分代码与注意事项发给大家看一下第一步:如果该报表需要分页的话,请将下面的2、"id="countSql"/>替换掉原先的。第二步:增加$j("#countSql").val("分页语句");请注意字符串的要写单引号:并且写成如下形式:\'${字符串}\'ShowExt.jsp修改成"funcBarLocation=""params="<%=param.toString()%>"needPageMark="yes"pageCount="20"totalCountExp="<3、%=countSql%>"paperHeight="600"/>附录:3.8. 分页计算标签本功能采用报表组的原理来实现,因此需要支持报表组的授权3.8.1. 概念定义使用分页计算标签可以在报表比较大的情况下实现以页为单位对数据进行读取和展现及导出等操作。3.8.2. 功能背景报表大到一定程度,必然会内存溢出,此时比较好的解决办法是边算边输出。分页计算标签是利用报表组来实现的逐页计算逐页输出的tag标签。可以大大降低内存占有量,提高运行效率,避免内存溢出等问题。3.8.3. 使用方法在这个标签中,主要增加了以下属性:t4、otalCountExp——总记录数(必填属性)分页就是基于这个总记录数来的。它的值是一个润乾的非数据集函数,并且返回的值应该是一个整型数据。如用query执行一个count的sql。如:totalCountExp="query('SELECTcount(*)FROMtable1')"pageCount——每页记录数(非必填)分页后每一页包含的记录数,其值需为整数。默认值为20。cachePageNum——缓存页数(非必填)根据pageCount和cachePageNum,每次取pageCount*cachePageN5、um条记录,其值需为整数,默认值为100设置该属性,可保证缓存页数内的翻页效率。(reportconfig.xml文件里的alwaysReloadDefine设置为no,exthtml标签里useCache设置为yes,该属性才生效)startRowParamName/endRowParamName——起始行参数名/结束行参数名(非必填)对应报表数据集记录行中设置的起始行和结束行的参数名。默认值为startRow和endRow。其他属性说明,与html标签基本一致:图 3.2. ·应用举例一:下面以订单明细列表为例,按6、照常规做出一张订单明细的清单式列表。然后为其添加两个参数:起始行参数名startRow和结束行参数名endRow。注意参数类型要求是整型。图 3.4. 并且在数据集设置的参数标签页设置好起始行和结束行的对应参数@startRow和@endRow。图 3.5. 下面是最简jsp发布文件,只定义了三个必须属性,其余均采用默认值:图 3.6. 运行结果如下:图 3.7. 下面是定义了各种属性之后的jsp:图 3.8. ·运行效果如下:图 3.9. 这种做法的缺点:当数据量足够大的时候,某些jdbc包的resultset本身会7、内存溢出;而且从理论上看,当调用api接口将resultset的指针定位到某一行的时候,其底层其实是一行一行跳转的,虽然速度非常快,但是数据量超过几百万甚至几千万的时候,还是会消耗一些时间。因此当记录数大到一定程度,翻到最后一页的速度会比开头几页慢。这种做法的优点:和数据库类型无关,任何一种数据库都可以采取这种方式,用户不用研究不同数据库的差别。emerito_info.raq的分页count语句--------------------------------------------------------------8、--------------selectcount(*)fromRETIRER_SALARYrs,RETIRER_SALARY_DETAILrsdWHERErsd.retierer_salary_id=rs.retierer_salary_idand(rs.unit_id=?or?isnull)and(rs.retierer_sa
2、"id="countSql"/>替换掉原先的。第二步:增加$j("#countSql").val("分页语句");请注意字符串的要写单引号:并且写成如下形式:\'${字符串}\'ShowExt.jsp修改成"funcBarLocation=""params="<%=param.toString()%>"needPageMark="yes"pageCount="20"totalCountExp="<
3、%=countSql%>"paperHeight="600"/>附录:3.8. 分页计算标签本功能采用报表组的原理来实现,因此需要支持报表组的授权3.8.1. 概念定义使用分页计算标签可以在报表比较大的情况下实现以页为单位对数据进行读取和展现及导出等操作。3.8.2. 功能背景报表大到一定程度,必然会内存溢出,此时比较好的解决办法是边算边输出。分页计算标签是利用报表组来实现的逐页计算逐页输出的tag标签。可以大大降低内存占有量,提高运行效率,避免内存溢出等问题。3.8.3. 使用方法在这个标签中,主要增加了以下属性:t
4、otalCountExp——总记录数(必填属性)分页就是基于这个总记录数来的。它的值是一个润乾的非数据集函数,并且返回的值应该是一个整型数据。如用query执行一个count的sql。如:totalCountExp="query('SELECTcount(*)FROMtable1')"pageCount——每页记录数(非必填)分页后每一页包含的记录数,其值需为整数。默认值为20。cachePageNum——缓存页数(非必填)根据pageCount和cachePageNum,每次取pageCount*cachePageN
5、um条记录,其值需为整数,默认值为100设置该属性,可保证缓存页数内的翻页效率。(reportconfig.xml文件里的alwaysReloadDefine设置为no,exthtml标签里useCache设置为yes,该属性才生效)startRowParamName/endRowParamName——起始行参数名/结束行参数名(非必填)对应报表数据集记录行中设置的起始行和结束行的参数名。默认值为startRow和endRow。其他属性说明,与html标签基本一致:图 3.2. ·应用举例一:下面以订单明细列表为例,按
6、照常规做出一张订单明细的清单式列表。然后为其添加两个参数:起始行参数名startRow和结束行参数名endRow。注意参数类型要求是整型。图 3.4. 并且在数据集设置的参数标签页设置好起始行和结束行的对应参数@startRow和@endRow。图 3.5. 下面是最简jsp发布文件,只定义了三个必须属性,其余均采用默认值:图 3.6. 运行结果如下:图 3.7. 下面是定义了各种属性之后的jsp:图 3.8. ·运行效果如下:图 3.9. 这种做法的缺点:当数据量足够大的时候,某些jdbc包的resultset本身会
7、内存溢出;而且从理论上看,当调用api接口将resultset的指针定位到某一行的时候,其底层其实是一行一行跳转的,虽然速度非常快,但是数据量超过几百万甚至几千万的时候,还是会消耗一些时间。因此当记录数大到一定程度,翻到最后一页的速度会比开头几页慢。这种做法的优点:和数据库类型无关,任何一种数据库都可以采取这种方式,用户不用研究不同数据库的差别。emerito_info.raq的分页count语句--------------------------------------------------------------
8、--------------selectcount(*)fromRETIRER_SALARYrs,RETIRER_SALARY_DETAILrsdWHERErsd.retierer_salary_id=rs.retierer_salary_idand(rs.unit_id=?or?isnull)and(rs.retierer_sa
此文档下载收益归作者所有