提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:郑恭琳|2020-01-19 14:39:53.250|阅读 570 次
概述:许多现代的报表生成器都允许您嵌入另一个报表,即所谓的子报表。通过以这种方式划分报表,您可以根据条件控制报表的结构。在FastReport.Net中,子报表仅在另一页上创建,并且可以访问与主报表相同的数据。主报表将一个子报表对象添加到您计划放置该子报表的位置。该对象是将立即创建的报表页面的链接。作为新报表页面的一部分,您可以创建所需的模式。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
许多现代的报表生成器都允许您嵌入另一个报表,即所谓的子报表。为什么要这么做?例如,为了方便设计报表。如果主报表和子报表具有不同的类型,则更容易分别创建它们。
此外,通过以这种方式划分报表,您可以根据条件控制报表的结构。例如,您在主报表中显示了一些基本信息,但是根据该数据或报表中的某些参数,将选择多个子报表之一。这使您的报表更具通用性。无需在不同情况下创建多个报表。
ActiveReports报表生成器的用户对此问题感到困惑:
我有一个包含两个子报表的报表。我想根据条件运行或不运行每个子报表。这可能吗?
技术支持回复:
是的,可以根据某些条件从父报表中选择子报表。例如,您可以在Detail的Format Event中使用SubReport控件的Visible属性,基于每次触发Detail.OnFormat事件时都会增加的计数器变量来控制子报表的可见性。
在FastReport.Net中,子报表仅在另一页上创建,并且可以访问与主报表相同的数据。主报表将一个子报表对象添加到您计划放置该子报表的位置。该对象是将立即创建的报表页面的链接。作为新报表页面的一部分,您可以创建所需的模式。
顺便说一句,您可以先创建一个包含多个页面的报表,然后,如果需要,可以添加一个子报表对象,并将其放在其属性中,以链接到所需页面。
让我们看一下如何根据条件制作带有子报表的报表。实际上,这个想法很简单。由于报表中包含脚本,因此我们将提供所需子报表的可见性。在这种情况下,子报表应放在同一位置,一个对象放在另一个对象上。
假设我们的报表显示了订单信息。还有一些与订单表相关的报表:订单详细信息、产品、客户。除了订单信息外,我们还要列出订单中的产品或客户信息。该报表具有一个参数,基于该参数我们将显示产品列表或客户信息。
主报表的模板非常简单:
有关订单的基本信息来自“Orders”订单表。在添加的字段旁边,我们有一个Subreport对象。在Subreport1属性中,您绝对应该将PrintOnParent属性设置为true。
当我们添加子报表对象时,会自动添加一个新的报表页面。在此页面上,我们创建一个子报表模板,该模板将显示产品列表。由于“Orders”订单表与“Order Details”订单明细相关联,因此该报表将显示与当前订单相对应的记录。订单明细表还具有与产品表的连接。我们将使用来自此连接的数据:
这就是为什么到字段的链接具有这样的视图的原因:Order Details.Products.ProductName。
现在,再添加一个子报表对象。将其放在Subreport1上。您还需要将PrintOnParent属性设置为true。
在第二个子报表模板中,我们从“Customers”客户表中添加一个与“Orders”订单表有联系的字段。
现在,我们有了一个包含两个子报表的报表。添加报表参数。可以从报表外部(例如,从用户程序)设置参数。
对于主报表中的Data band,创建一个处理程序BeforePrint事件:
private void Data1_BeforePrint(object sender, EventArgs e) { if ((int)Report.GetParameterValue("Parameter") == 1) { Subreport1.Visible = false; Subreport2.Visible = true; } else { Subreport1.Visible = true; Subreport2.Visible = false; } }
代码很简单,因此实际上基本的编程技能足以创建此类报表。
结果,产品列表将如下所示:
客户信息表将如下所示:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
一款全功能的Windows Forms、ASP.NET和MVC报表分析解决方案。
ActiveReports亚洲畅销的.NET报表控件,20万用户的选择,可在应用程序中生成各种报表,十多年来一直荣获应用程序的优秀报表生成控件。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢