【报表制作技巧】动态列报表的制作「建议收藏」

【报表制作技巧】动态列报表的制作「建议收藏」【报表制作技巧】动态列报表的制作

大家好,又见面了,我是你们的朋友全栈君。

在数据信息系统中,常常会看到这样一类报表需求,它们往往格式简单,一般为列表式明细报表,但是要显示的列很多。而不同终端用户在不同时刻关心的数据又不同,这样就要求报表能够让他们随心所欲的选择要显示的列,以便直观地查看数据。最终效果如下图所示:

那怎么实现这种需求呢?

多做几个典型报表,根据用户不同进行不同的加载?这样报表开发工作量就增加了,连吃鸡的时间都没有了;

写个存储过程动态计算要显示的表字段?还需要调试存储过程。

有没有更简单高效的实现方法???——当然必须有,下面看我放大招。

工欲善其事,必先利其器。我们选择的利器就是:润乾报表,具体实现操作如下:

首先,在数据集上通过sql实现动态取数

根据需求效果,我们需要定义两个参数,用于接收要显示的表和字段信息:

对应数据集sql配置如下:

【技巧】${参数名}为参数的高级用法,可以在报表中动态的进行表达式的替换,快速实现动态执行语句的拼接。

然后,在报表单元格表达式中实现动态显示字段

其中,

B1单元格:=to(1,ds1.fcount()) 并设置扩展方式为横向扩展,用于计算需要显示的列数

B2单元格:=ds1.fname(B1) 跟随B1扩展,用于动态显示列名称

A3单元格:=ds1.select(#0) 根据数据集的行数进行纵向扩展

B3单元格:=ds1.field(B1) 用于动态显示对应字段数据

A列为协助实现效果列,故需要选择该列,设置该列隐藏。

最后,我们制作一下参数模板,方便用户选择自己想要显示的表和列数据

设置B2和D2编辑风格为下拉数据集(数据集为提前准备好的内建数据集),并在D2设置关联过滤,便于用户了解对应表下有哪些字段供选择,进行数据分析。

好了,一个完美的动态列报表就完成了,我们来回顾一下其中遇到的问题和解决的技巧:

1.数据集sql实现动态取数

【技巧】使用参数的${参数名}用法

2.单元格表达式实现动态显示字段

【技巧】使用数据集函数ds.field()和ds.fieldname()

至此,动态列报表制作就完成了,我们仅仅使用了润乾报表的参数特殊用法和数据集函数就做好了动态列报表,这一波操作6不6?快来加入润乾大家庭,更多快速简便的报表制作方式等你来挖掘。

转载于:https://juejin.im/post/5b7d1be3f265da433f2a164d

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107351.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • uefi shell 修复引导_磁盘主引导损坏怎么办

    uefi shell 修复引导_磁盘主引导损坏怎么办1、 红旗DC5.032bit莫名其妙死机,(服务器是ibmx36502008年左右的机器),硬重启后无法启动,极其缓慢,到最后报错:a)        Init:cannotexecute“etc/rc.d/rc”b)       各种初始化失败,root卷组无法挂载;c)        服务器四块盘,只有一块不停地闪烁,其他几乎没有响应;d)       初步判断,

    2022年8月20日
    35
  • jedispool使用自动归还jedis解决方案「建议收藏」

    jedispool使用自动归还jedis解决方案「建议收藏」在使用Jedispool的时候遇到一个尴尬的问题。实例必须要手动归还。即jedis高版本使用jedis.close()归还。这样据说是灵活的表现。但如果必须手动调close,那么万一项目组的成员手抖忘记掉了,这就无疑会出现很严重的情况,这无疑增加了系统的脆弱性。由于我们系统是用grpc做通信机制,所以不存在通过spring管理实例的生命周期来控制,经研究决定也决定不采用Redisson.那接

    2025年9月13日
    5
  • pycharm2021.11.3激活补丁_最新在线免费激活

    (pycharm2021.11.3激活补丁)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月30日
    69
  • css页面自适应屏幕大小_html图片自适应屏幕

    css页面自适应屏幕大小_html图片自适应屏幕两种方法(1)原生自适应@mediascreen表示当屏幕大于320px,并小于1156px是执行下面的css@mediascreenand(min-width:320px)and(max-width:1156px){ .site-bg-dl{ position:fixed; height:100%; widt

    2022年8月13日
    3
  • 双机热备方案设计

    1什么是双机热备方案  双机热备就是使用互为备份的两台服务器共同执行同一服务,其中一台主机为工作机(PrimaryServer),另一台主机为备份机(StandbyServer),保证系统不间断的运行。双机热备软件就是实现上述功能的软件产品。双机热备针对的是服务器的临时故障所做的一种备份技术,通过双机热备,来避免长时间的服务中断,保证系统长期、可靠的服务。  企事业机构的信息化建设已…

    2022年4月6日
    45
  • cdn加速配置_开启cdn加速

    cdn加速配置_开启cdn加速配置方法同上篇文章一样CDN加速配置,阿里云cdn内配置好以后即可剩下把前端服务器nginx内的证书文件上传以及配置写好即可。后端服务器也同上配置证书下载上传服务器配置好nginx即可。如果都配置好以后,不可以访问时,注意查看前端请求接口是否为https方式。如果为http时,检查是否更新服务器成功,如果成功后还不可以正常访问时,前端修改代码如下:vue.config.js内添加下行代码。index.html下添加代码:https:true完毕!…

    2022年8月19日
    18

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号