Setting the datasource for a Local Report - .NET & Report Viewer

前端 未结 3 1374
野趣味
野趣味 2020-11-29 06:42

I have created a custom control (a windows form with a report viewer). I have the following code to load a local report:

Contained in CustomReportViewer Clas

相关标签:
3条回答
  • 2020-11-29 07:27

    you may be able to just use a datatable instead of a dataset. change this:

    DataSet ds = new DataSet();
    da.Fill(ds);
    DataTable dt = ds.Tables[0];
    

    to this:

    DataTable dt = new DataTable();
    da.Fill(dt);
    

    and this:

    reportDataSource.Value = ds.Tables[0];
    

    to this

    reportDataSource.Value = dt;
    
    0 讨论(0)
  • 2020-11-29 07:33

    The key for me was as answered by StuartLC as above... with further clarification in that when he said it "Must match the DataSource in the RDLC".. it actually turned out to be the "DataSetName" element value re: <DataSetName>DataSet1</DataSetName>

    I went round and round because it is called "DataSource" so I kept using the DataSource element name but apparently in the rdl and rdlc file this really signifies the DataSetName. So keeping that in mind here is the code as borrowed from Stuart above with my own. Note the DataSetName element value:

            using (SqlConnection sqlConn = new SqlConnection(rvConnection))
            using (SqlDataAdapter da = new SqlDataAdapter(rvSQL, rvConnection))
            {
                DataSet ds = new DataSet();
                da.Fill(ds);
                DataTable dt = ds.Tables[0];
    
                this.reportViewer1.Reset();
                this.reportViewer1.ProcessingMode = ProcessingMode.Local; 
                this.reportViewer1.LocalReport.ReportPath = AppDomain.CurrentDomain.BaseDirectory + "ssrsExport.rdlc";
                ReportDataSource reportDataSource = new ReportDataSource();
                // Must match the DataSet in the RDLC
                reportDataSource.Name = "DataSet1"; 
                reportDataSource.Value = ds.Tables[0];
                this.reportViewer1.LocalReport.DataSources.Add(reportDataSource);   
                this.reportViewer1.RefreshReport();
            }
    
    0 讨论(0)
  • 2020-11-29 07:40

    You need to create a ReportDataSource, and set its Value property - e.g. DataTable and IEnumerables are supported sources

    As an example, and assuming that a method exists to return a DataSet, with a single DataTable matching the columns needed by your report:

    DataSet ds = SomeMethodToRetrieveDataSet(); // e.g. via DataAdapter
    // If your report needs parameters, they need to be set ...
    ReportParameter[] parameters = new ReportParameter[...];
    
    ReportDataSource reportDataSource = new ReportDataSource();
    // Must match the DataSource in the RDLC
    reportDataSource.Name = "ReportData"; 
    reportDataSource.Value = ds.Tables[0];
    
    // Add any parameters to the collection
    reportViewer1.LocalReport.SetParameters(parameters); 
    reportViewer1.LocalReport.DataSources.Add(reportDataSource);
    reportViewer1.DataBind();
    

    Note that it is often easier to just embed the RDLC into your assembly, rather than having to retain separate RDLC files. Do this by selecting the Build Action on the RDLC as Embedded Resource, and then you can set the ReportEmbeddedResource property:

    reportViewer1.LocalReport.ReportEmbeddedResource = 
                             "MyOrganisation.MyAssembly.NameSpace.MyReportName.rdlc";
    

    Note that the resource string must include the fully qualified name of the resource (including Assembly).

    0 讨论(0)
提交回复
热议问题