最近在看报表这一块,在网上找到的大都是连接数据库的,对于自定义的DataTable数据没有详细的连接说明,经过一番寻找,总结一下大概方法,大神请直接无视
1、添加一个数据集
data:image/s3,"s3://crabby-images/0640b/0640bbc265925c275eb2cef2c4c0e4b9af7d6683" alt=""
点确定后界面如下
data:image/s3,"s3://crabby-images/bdc05/bdc05701ee708c0b4d39222071dfd702e21ac3ce" alt=""
在空白处右键
data:image/s3,"s3://crabby-images/a0bec/a0bec0618e2993ae94f4fbf65643bb8b7703c4cb" alt=""
修改名称
data:image/s3,"s3://crabby-images/9ed0c/9ed0c0755efd4f649394528fb4daeb0824c32763" alt=""
添加行
data:image/s3,"s3://crabby-images/65689/65689fdbc88ac600aa5d20a596a625f91624cdb0" alt=""
重命名行
data:image/s3,"s3://crabby-images/e241c/e241c165d81699ca19212f709dd2609c297eb41d" alt=""
表效果
data:image/s3,"s3://crabby-images/6a087/6a0875a37d10c261bd71303caf460c07faaa7175" alt=""
2、添加报表
data:image/s3,"s3://crabby-images/aa511/aa5115b9de0f24ad4f6de08bfa8b474289c9a721" alt=""
确定后出现下面界面
data:image/s3,"s3://crabby-images/f9a3b/f9a3b07b3b5f298ac99b5f259b75ef5231da3676" alt=""
然后添加资料数据源
data:image/s3,"s3://crabby-images/02329/02329ee23942e3b64e79fe71decbf6c755194dc7" alt=""
点击新增,选择资料集,出现下面界面
data:image/s3,"s3://crabby-images/33392/3339226840b126e4eda9315801ebaec5f6452445" alt=""
输入名称为message,资料来源选择DataSet1,也就是你创建的DataSet1文件,资料集选择mytable,点击确定
data:image/s3,"s3://crabby-images/985d1/985d1fadf9bb409b50898215f55ad1ec00b3851c" alt=""
然后在工具栏里拉一个资料表到报表上,然后如下
data:image/s3,"s3://crabby-images/7d349/7d34933ed18867893597bfec871e24742669c4a1" alt=""
再如下
data:image/s3,"s3://crabby-images/f5c9d/f5c9d41862abf6b6fca2557b40e67ca56dbd79a8" alt=""
保存,报表完成,
下面搞窗体,拉一个ReportViewer控件到窗体上,
data:image/s3,"s3://crabby-images/c7816/c781660cffbfd563f6b1af36c5298a4d0f175cc2" alt=""
如果工具箱内找不到的话就自己添加进来一个,如下
data:image/s3,"s3://crabby-images/8fe62/8fe629f5dad34e364af935e245723bf0dbb00f9f" alt=""
然后在窗体的load事件里写代码 如下
1 DataTable dt = new DataTable();
2 dt.Columns.Add(new DataColumn("row1", typeof(string)));
3 dt.Columns.Add(new DataColumn("row2", typeof(string)));
4 for (int i = 0; i < 6; i++)
5 {
6 DataRow dr = dt.NewRow();
7 dr[0] = "a";
8 dr[1] = "b";
9 dt.Rows.Add(dr);
10 }
11 reportViewer1.LocalReport.ReportPath = Application.StartupPath + "\\Report1.rdlc";
12 //指定数据集,数据集名称后为表,不是DataSet类型的数据集
13 this.reportViewer1.LocalReport.DataSources.Clear();
14 this.reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporting.WinForms.ReportDataSource("message", dt));
//在vs2005中没有找到重命名为messge的方法,这里这样写
// this.reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporting.WinForms.ReportDataSource("DataSet1_mytable",dt));
15 //显示报表
16 this.reportViewer1.RefreshReport();
运行一下看看
data:image/s3,"s3://crabby-images/01f4c/01f4c5cd78d46bd7b4e0db46159da1f626de570e" alt=""
注意:
第2和3行的列名要和数据集DataSet1里的列名一致
第11行的文件名要和你添加的报表文件名一致,路径要正确
第14行的message要和报表里的那个数据集的名称对应