Calling Drillthrough report in rdlc

后端 未结 1 940
星月不相逢
星月不相逢 2020-12-06 14:40

I have a rdlc report name attendence.rdlc which take three parameter employeeId,monthId and year to generate employee\'s monthly attendance status.Like

相关标签:
1条回答
  • 2020-12-06 15:16

    My problem have been solved.In rdlc when someone calling goto_report/goto_url..it's actually called by Drillthrough report.So if i create na even handler obviously outside of postback url like

     protected void Page_Load(object sender, EventArgs e)
     { 
    
     if (!IsPostBack)
        {
           //otherscode u need
           //now call report first time
          string path = HttpContext.Current.Server.MapPath(your report path);
          ReportViewer1.Reset(); //important
          ReportViewer1.ProcessingMode = ProcessingMode.Local;
          ReportViewer1.LocalReport.EnableHyperlinks = true;
    
          LocalReport objReport = ReportViewer1.LocalReport;
          objReport.DataSources.Clear();
          objReport.ReportPath = path;
    
          // Add Parameter if you need
          List<ReportParameter> parameters = new List<ReportParameter>();
          parameters.Add(new ReportParameter("parameterName", ParameterValue));
          ReportViewer1.LocalReport.SetParameters(parameters);
          ReportViewer1.ShowParameterPrompts = false;
          ReportViewer1.ShowPromptAreaButton = false;
          ReportViewer1.LocalReport.Refresh();
    
          //Add Datasourdce
          ReportDataSource reportDataSource = new ReportDataSource();
          reportDataSource.Name = "odsReportData";
          reportDataSource.Value = YourReportDataSourseValue;
          objReport.DataSources.Add(reportDataSource);
          objReport.Refresh();
        }
    
        ReportViewer1.Drillthrough += new DrillthroughEventHandler(DemoDrillthroughEventHandler);
    
        }
    
    
    
    
    
    
    
       public void DemoDrillthroughEventHandler(object sender, DrillthroughEventArgs e)
       {
      /*Collect report parameter from drillthrough report*/
        ReportParameterInfoCollection DrillThroughValues = e.Report.GetParameters();
        Type parameterName = Type.Parse(DrillThroughValues[1].Values[0].ToString());
    
      /*Bind data source with report*/
        LocalReport localReport = (LocalReport)e.Report;
        localReport.DataSources.Clear();
        localReport.DataSources.Add(new ReportDataSource("odsData", reportData));
        localReport.EnableHyperlinks = true;     
    
       /*Add parameter to the report if report have paramerter*/
        List<ReportParameter> parameters = new List<ReportParameter>();
        parameters.Add(new ReportParameter("ParameterName", ParameterValue));
        localReport.SetParameters(parameters);
        localReport.Refresh();
    }
    
    0 讨论(0)
提交回复
热议问题