这几天一直想要实现rdlc报表绑定datagridview中的数据,始终在虚拟表向rdlc报表绑定这一步上出错。今天从下午4点到七点四十一直在尝试。最终还是实现了,最然并不知所以然,这个问题还是以后在考虑吧,目前的项目要紧。
首先是 datagridview中的数据传到虚拟表中。
for (int i = 0; i < dgvscan.Columns.Count - 1; i++)
                {
                    dtout.Columns.Add(dgvscan.Columns[i].Name);
                }
                //添加行
                for (int j = 0; j < dgvscan.Rows.Count - 1; j++)
                {
                    DataRow dr = dtout.NewRow();
                    for (int k = 0; k < dgvscan.Columns.Count - 1; k++)
                    {
                        dr[k] = dgvscan.Rows[j].Cells[k].Value;
                    }
                    dtout.Rows.Add(dr);
                }
                reportout frmReporterOut = new reportout(dtout);
                frmReporterOut.Show();
然后是虚拟表绑定到报表
private void reportout_Load(object sender, EventArgs e)
        {
            ReportDataSource rdlc = new ReportDataSource("DataSet2", dtout);
            reportViewer1.LocalReport.DataSources[0] = rdlc; //最好不要用add ----假设此行行数为n
            //this.reportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet2", dtout));//之前这句代码一直不行
            this.reportViewer1.RefreshReport();
        }
最开始 上面注释掉的那行代码总是实现不了功能,换了一行才行,然而并不知道为什么。
忽然一想,
reportViewer1.LocalReport.DataSources.Clear();
this.reportViewer1.LocalReport.DataSources.Add(rdlc);
这样就可以了,试了一下真可以。最开始应该是在控件编辑的时候为rdlc绑定了数据源,需要重新清除重新绑定。单纯的add无法实现数据源的覆盖
vs 2015 rdlc报表绑定datagridview中的数据
原文:http://www.cnblogs.com/jml-blog/p/7522492.html