如何根据父报表的条件显示子报表
许多现代的报表生成器都允许您嵌入另一个报表,即所谓的子报表。为什么要这么做?例如,为了方便设计报表。如果主报表和子报表具有不同的类型,则更容易分别创建它们。
此外,通过以这种方式划分报表,您可以根据条件控制报表的结构。例如,您在主报表中显示了一些基本信息,但是根据该数据或报表中的某些参数,将选择多个子报表之一。这使您的报表更具通用性。无需在不同情况下创建多个报表。
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; } }
代码很简单,因此实际上基本的编程技能足以创建此类报表。
结果,产品列表将如下所示:
客户信息表将如下所示: