现在的位置: 首页 > 综合 > 正文

rdlc(三,四)

2013年09月06日 ⁄ 综合 ⁄ 共 2985字 ⁄ 字号 评论关闭

 

使用RDLC报表(三、四)

技术类文章   2009-10-13 15:17   阅读4   评论0  
字号:    

使用RDLC报表三:

在使用报表向客户展示结果数据时,实时的在报表中显示某些特定的数据是必需的,如:显示的部门、打印的日期等。本文只简单的演示向报表内传入一个字符值。如有其它问题,欢迎讨论。

1、新建一个工程TestReport,一个Form窗体,放入一个TextBox、一个Button按钮,再放入一个ReportViewer控件。

2、在ReportViewer上选择新建一个报表

3、在打开的报表设计器中,选择工具栏的“报表”中的“报表参数”,新加一个参数,名称为content,数据类型为string,确定。

4、在报表设计器的页面上放入一个文本框,在文本框上按鼠标右键->属性,在“文本框属性”窗口中,选择“常规”选项卡内下部的“值”后面的“编辑表达式”按钮(就是那个Fx),在此窗口内,左下框内选择参数,在右下框将会出现在上一步中设置的参数,双击此参数,在上面的框内将出现所需要的表达式:=Parameters!content.Value。保存此报表。报表默认名称为Report1.rdlc。

5、在Form窗体内双击按钮,编写如下代码:

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.LocalReport.ReportEmbeddedResource = "TestReport.Report1.rdlc";

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香             ReportParameter rp = new ReportParameter("content", this.textBox1.Text);

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.LocalReport.SetParameters(new ReportParameter[] { rp });

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.RefreshReport();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

6、运行工程,在文本输入框内输入数据,按下按钮,数据是不是已经传入报表了?

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

 

 

 

 

 

使用RDLC报表四:

本文内以MSServer自带Northwind库文件内的Customers及Orders这两个表为例,建立两个报表文件,在查询得出Customers的表数据后,点击此表内的CustomerID数据,报表将转入至下一个报表,并显示与之相关的Orders的数据,即VS中所谓的钻取式报表。

1、打开一个工程,并新建一个From,放入一个Button及一个ReportViewer控件。

2、在工程内新建一个数据源,连接到Northwind库文件,显示Customers及Orders这两个表

3、新建一个报表文件,并以表格的形式来显示数据,将Customers表内的CustomerID、CompanyName及Address三个字段放入,形成一份有表头及数据的简单报表,并将此报表保存命名为customerReport

4、再建一个报表文件,与customerReport相同,也以表格的形式来显示报表,将Orders内的OrderID、CustomerID、ShipName及OrderDate四个字段放入表格内,报表保存为orderReport

5、orderReport的数据源根据主报表customerReport的数据来确定数据源的数据,查看表格的数据集名称,我的显示为NorthwindDataSet_Orders,也可以自己另建一个,具体方法见我的《RDLC报表(二)》

6、再打开customerReport报表,将CustomerID设置成为可点击的索引字段,以便转入下一个报表。选择CustomerID字段,按鼠标右键,在”文本框属性“窗口中,选择”导航“选项卡,在下面的”超链接“中选择”跳至报表“,在报表名称中选择”orderReport“,再按下后面的”参数...“按钮,输入一个参数名称,如customerid,参数值选择=Fields!CustomerID.Value。为了与其它数据相区分,可以将此列数据根据自己的习惯改变颜色或加下划线

7、在orderReport中,设置一个报表参数,与CurtomerReprot中的名称相同,以接收父表中传入的参数

8、新建两个取得数据的方法,一个从Customers中取得数据集,另一个从Orders中取得数据集,且带参数。此两个方法可以自己编写类库来实现,也可以在VS的数据集内添加。为了演示方便,我直接使用了Customers的GetData(),并编写了一个Orders的GetDataByCustomerID(@cid)的方法。

9、在From的Button中编写如下代码:

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香        private void button2_Click(object sender, EventArgs e)

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香        {

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香             NorthwindDataSet.CustomersDataTable dt1 = new NorthwindDataSetTableAdapters.CustomersTableAdapter().GetData();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.LocalReport.ReportEmbeddedResource = "TestReport.customerReport.rdlc";

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.LocalReport.DataSources.Clear();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.LocalReport.DataSources.Add(new ReportDataSource("NorthwindDataSet_Customers", dt1));

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            this.reportViewer1.RefreshReport();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香         }

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

10、使用报表的Drillthrough事件,当选择了钻取项时会发生此事件,给下一个报表取值,代码如下:

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香        private void reportViewer1_Drillthrough(object sender, DrillthroughEventArgs e)

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香        {

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香             LocalReport lp = (LocalReport)e.Report;

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香            string customerid = lp.GetParameters()["customerid"].Values[0].Trim();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香             lp.DataSources.Clear();

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香             lp.DataSources.Add(new ReportDataSource("NorthwindDataSet_Orders",

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香                new NorthwindDataSetTableAdapters.OrdersTableAdapter().GetDataByCustomerID(customerid)));

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香         }

 

运到结果:

运行第一份报表:

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

钻取后运行第二份报表:

使用RDLC报表(三、四) - 琴瑟谷香 - 琴瑟谷香

抱歉!评论已关闭.