分页标签中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('SELECT count(*) 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('{call RQ_TEST_CUR(?)} ','@@result')" //call执行一个count的存储过程。
/>
此用法比较特殊,由于存储过程的特性,我们可以在存储过程里完成复杂的逻辑运算传参等,然后查询出需要的总记录数.上面的用法针对oracle数据库存储过程的方法,其他数据库的写法大致相同.
其中:RQ_TEST_CUR(?)为存储过程的名字,?代表输出参数(游标类型),后面的@@result与?进行绑定.
4.从报表模版中的数据集中读取已建立好的数据集sql,当作总记录数.
第一步,从报表模版里获取sql
第二步,把这个sql根据第2种办法赋值给标签.
以上就是分页标签中totalCountExp的几种用法,通过润乾丰富的API和页面处理,还可以组合出更多样的方法.
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);
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. 使用 `java.sql.Statement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 2. 使用 `java.sql.PreparedStatement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 3. 使用 `SELECT` 语句的 `LIMIT` 和 `OFFSET` 子句来限制查询返回的行数。 4. 使用 `java.sql.Statement` 或 `java.sql.PreparedStatement` 对象的 `executeQuery` 方法执行带有 `LIMIT` 和 `OFFSET` 子句的 `SELECT` 语句,然后使用 `java.sql.ResultSet` 类的 `next` 方法来遍历查询结果。 5. 使用数据库的特定功能(如 MySQL 的 `LIMIT` 子句)来实现分页。这种方法的实现方式取决于数据库的类型。 ### 回答2: Java实现分页查询的几种常用方法有: 1.使用SQL语句的LIMIT关键字:在查询数据库时,可以使用LIMIT关键字来指定查询结果的起始位置和数量。通过计算页号PageNum和每页数量PageSize,可以得到SQL语句的LIMIT子句,从而实现分页查询。 2.使用MyBatis的分页插件:MyBatis是一种优秀的持久化框架,在其配置文件可以配置分页插件,并使用插件提供的分页功能完成分页查询。通过在Mapper接口定义查询方法,并在配置文件配置插件,可以方便地实现分页逻辑。 3.使用Spring Data JPA的分页查询:Spring Data JPA是一种简化数据库操作的框架,可以通过定义Repository接口来实现数据的增删改查操作。在查询方法,可以使用Pageable参数来指定查询结果的起始位置和数量,从而实现分页查询。 4.使用PageHelper插件:PageHelper是一种基于MyBatis的分页插件,提供了丰富的分页查询功能。在查询方法,可以通过调用PageHelper.startPage方法来指定页号和每页数量,PageHelper会自动在SQL语句添加LIMIT子句,从而实现分页查询。 5.使用自定义工具类:可以自定义一个工具类来实现分页查询逻辑。通过传入查询结果集合、页号和每页数量,可以在工具类进行计算,得到分页查询的结果集合。 以上是Java实现分页查询的几种常用方法,根据项目的需求和使用的框架,可以选择适合的方法来实现分页功能。 ### 回答3: Java实现分页查询有多种方法,以下是几种常见的实现方式: 1. 使用数据库的分页查询:在SQL语句使用LIMIT关键字,通过设置偏移量和每页显示的数据条数,实现分页效果。例如,使用MySQL数据库时,可以通过"SELECT * FROM table_name LIMIT offset, limit"语句来实现分页查询。 2. 使用集合分页:将查询结果全部加载到内存的集合,然后通过对集合进行切片操作,截取指定页的数据,实现分页效果。常见的集合类如List、ArrayList等都提供了subList方法,可以方便地实现分页。 3. 使用ORM框架:ORM(Object-Relational Mapping)框架如Hibernate、MyBatis等,提供了丰富的分页查询功能。通常只需在查询方法传入页码和每页显示的数据数量,框架会自动生成对应的分页查询SQL语句,并返回分页查询结果。 4. 使用第三方库:有一些开源的分页查询库可以直接使用,如PageHelper、Spring Data JPA等。这些库提供了简单易用的API,可以快速实现分页查询功能。 需要注意的是,无论使用哪种方法实现分页查询,都要考虑性能和数据量。当处理大数据量时,应尽量减少数据库查询次数,避免一次性加载全部数据;同时,合理使用缓存、索引等技术,提高查询效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值