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

许多现代的 表生成器都允许您嵌入另一个 表,即所谓的子 表。通过以这种方式划分 表,您可以根据条件控制 表的结构。在FastReport.Net中,子 表仅在另一页上创建,并且可以访问与主 表相同的数据。主 表将一个子 表对象添加到您计划放置该子 表的位置。该对象是将立即创建的 表页面的链接。作为新 表页面的一部分,您可以创建所需的模式。

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

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

ActiveReports 表生成器的用户对此问题感到困惑:

我有一个包含两个子 表的 表。我想根据条件运行或不运行每个子 表。这可能吗/em>

技术支持回复:

是的,可以根据某些条件从父 表中选择子 表。例如,您可以在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; } }

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

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

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

客户信息表将如下所示:

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

 

 

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

标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2020年1月16日
下一篇 2020年1月16日

相关推荐

发表回复

登录后才能评论