如何在RDLC中处理子报表的子报表?

6
我有一个包含几个子报告的RDLC报告。我正在使用LocalReport_SubreportProcessing事件处理所有这些子报告。现在,在这些子报告中,有一个报告再次有其子报告。我不知道如何处理这个子报告?
对于主报告,我已经添加了一个事件。
viewer.LocalReport.SubreportProcessing += new SubreportProcessingEventHandler(LocalReport_SubreportProcessing);
    viewer.LocalReport.Refresh();

事件代码

void LocalReport_SubreportProcessing(object sender, SubreportProcessingEventArgs e)
{      
    if (e.ReportPath == "rpt_PSRUserHoursDetail")
    {
        //Code
    }
    else if (e.ReportPath == "rpt_BEnchMiscDetails")
    {

        System.Data.DataTable dtBenchMiscSubReport =DataTable
        ReportDataSource subRptSource = new ReportDataSource("DataSource", dtBenchMiscSubReport);
        e.DataSources.Add(subRptSource);

        (sender as Microsoft.Reporting.WebForms.LocalReport).SubreportProcessing += new SubreportProcessingEventHandler(LocalReport_SubreportProcessingBench);

        CommonHelper.DisposeOf(dtBenchMiscSubReport);
    }
}

处理子报表的代码如下:

void LocalReport_SubreportProcessingBench(object sender, SubreportProcessingEventArgs e)
{
    int intProjectID = 0;
    int int_UserID = 0;

    if (e.Parameters.Count > 0 && e.ReportPath=="SubMiscellaneousTaskReport")
    {
        //get parameter

    }

    DateTime dtCurrentMonth = clsCheckDBNull.ToDate(string.Format("{0}-{1}-{2}", drpYear.SelectedValue, drpMonth.SelectedValue, "01"));
    if (e.ReportPath == "SubMiscellaneousTaskReport")
    {
        System.Data.DataTable dt = DataTable
        ReportDataSource subRptSource = new ReportDataSource("Dataset1", dt);
        e.DataSources.Add(subRptSource);
    }
}
2个回答

1

我已经找到了传递参数给子报表的方法:

public partial class FormReportViewerAsnDetailed : Form
{
    private readonly int PoID;

    public FormReportViewerAsnDetailed(int PoID)
    {
        this.PoID = PoID;
        InitializeComponent();
        reportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet1", bindingSource1));
        reportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet2", bindingSource2));
        reportViewer1.LocalReport.SubreportProcessing += LocalReport_SubreportProcessing;
    }

    private void LocalReport_SubreportProcessing(object sender, SubreportProcessingEventArgs e)
    {
        if (e.Parameters.Any(k => k.Name == "AsnID")) //is it asn subreport?
        {
            var asn = int.Parse(e.Parameters["AsnID"].Values.First());

            asn_Details_ReportTableAdapter1.Fill(viewAsnDetailsDataSet1.Asn_Details_Report, asn);
            e.DataSources.Add(new ReportDataSource("DataSet2",
                new BindingSource(viewAsnDetailsDataSet1, "Asn_Details_Report")));

            inbound_By_AsnTableAdapter1.Fill(inboundsReportDataSet1.Inbound_By_Asn, asn);
            e.DataSources.Add(new ReportDataSource("DataSet1",
                new BindingSource(inboundsReportDataSet1, "Inbound_By_Asn")));
        }
        else // subreport of subreport
        {
            inbound_Items_ReportTableAdapter1.Fill(inboundItemsReportDataSet1.Inbound_Items_Report,
                int.Parse(e.Parameters["InboundID"].Values.First()));
            BindingSource src = new BindingSource(inboundItemsReportDataSet1, "Inbound_Items_Report");
            e.DataSources.Add(new ReportDataSource("DataSet1", src));
        }
    }

    private void FormReportViewer_Load(object sender, EventArgs e)
    {
        this.purchase_Order_Details_ReportTableAdapter1.Fill(
            purchaseOrderDetialsReport1.Purchase_Order_Details_Report, PoID);
        asn_Select_By_POTableAdapter1.Fill(asnDetailedList1.Asn_Select_By_PO, PoID);
        reportViewer1.LocalReport.SetParameters(new ReportParameter("po", PoID.ToString()));
        this.reportViewer1.RefreshReport();
    }
}

这里,我有两个数据集用于主报告。它们在构造函数中传递,并在加载方法中与主报告参数一起填充。

在子报告处理中,您需要确定是谁调用了子报告:子报告还是子报告的子报告?然后,您需要向每个数据源传递数据。


1

@chirag Fanse: 子报表本身就是一份报告。当你有一个子报表(比如A)的子报表(比如B)时,现在B将成为你的主报表,而A将成为子报表。因此,您可以像这样检查子报表:

if (e.ReportPath == "A")

而其他的东西将保持不变。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接