在润乾官方在线 demo的 "交互报表" 中,有介绍 "点击表头排序" 的报表案例,该报表针对普通统计类报表。对于使用大数据集的报表,当按照此方式改造时发现排序没起做用或仅对第一页或前几页排序,后面的都没成功。html
要想了解啥缘由致使?就须要分析该报表的作法及知道大数据集的取数原理。前端
首先,来分析下在线 demo“点击报表排序”的作法。sql
润乾报表中实现排序的方式有两种:缓存
一、 借助数据集 sql,即 order by …jsp
二、 数据集函数函数
如ds.select()大数据
都有排序表达式 sort_exp 或 order_exp.设计
示例中用的是第 2 中方法,因普通报表是一次性把全部数据取到内存,因此数据集函数排序是对全部数据的排序,点表头实际就是按照某字段对全部数据排了一次序,也就没啥问题了。3d
接下来看大数据集报表的取数原理。htm
简单来讲,大数据集取数原理是为了不一次取大量数据致使内存溢出,采起了游标方式边取边呈现的方案(其中取出的数据缓存在磁盘文件,前端呈现从缓存文件读取)。
了解了该方案后,咱们就清楚了,采用排序的第 2 中方案,显然只能针对一部分数据排序后呈现,并不针对全部数据。
解决方案也就明确了:要想实现大数据集报表的表头排序,必须用第 1 中方法。
改造:
一、 去掉数据集函数排序
三、 修改超连接
因普通报表和大数据集报表用的 jsp 不一样,因此要改一下。
以 B4 为例,把 showReport.jsp 改成 showBigReport.jsp
四、 报表属性内把数据集改成大数据集
经过以上 4 步,就能够完成点击表头排序功能从普通到支持大数据集。另外若是想实现升降序切换也很简单,除了点表头传排序的字段名外,再传一个 asc 或 desc 的排序方式拼到 SQL 中便可。只要知道了原理及方案,改造起来相对轻松。
Ps:"点击表头排序" 的示例报表,在设计器 demo 内也有,可在 "交互报表" 目录获取。