FastReport中国社区FastReport联系电话 联系电话:023-68661681

如何根据父报表的条件显示子报表

来源:   发布时间:2020-01-19   浏览:5015次

许多现代的报表生成器都允许您嵌入另一个报表,即所谓的子报表。为什么要这么做?例如,为了方便设计报表。如果主报表和子报表具有不同的类型,则更容易分别创建它们。

此外,通过以这种方式划分报表,您可以根据条件控制报表的结构。例如,您在主报表中显示了一些基本信息,但是根据该数据或报表中的某些参数,将选择多个子报表之一。这使您的报表更具通用性。无需在不同情况下创建多个报表。

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;
 }
 }

代码很简单,因此实际上基本的编程技能足以创建此类报表。

结果,产品列表将如下所示:

如何根据父报表的条件显示子报表

客户信息表将如下所示:

如何根据父报表的条件显示子报表

产品介绍 | 下载试用 | 优惠活动 | 在线客服

本站文章除注明转载外,均为本站原创或翻译
欢迎任何形式的转载,但请务必注明出处,尊重他人劳动成果
转载请注明:文章转载自:FastReport控件中文网 [https://www.fastreportcn.com/]
本文地址:https://www.fastreportcn.com/post/2679.html

相关产品: FastReport.Net,


联系我们
  • 重庆总部 023-68661681
购买
  • sales@evget.com
合作
  • business@evget.com


在线
客服
微信
QQ 电话
023-68661681
返回
顶部