C#reportviwer控件<转>

C#报表控件ReportViewer的使用(转)

启动VS2005新建一个窗体项目,命名为TestProj

C#reportviwer控件<转>_第1张图片

在左边的窗体内选择“添加新数据源”或在菜单上操作“添加新数据源”:

选择后出现对话窗体,选择“数据库”,进入“下一步”:

C#reportviwer控件<转>_第2张图片

本数据源以SqlServer2000所提供的Northwind数据库为例,因此在数据库内选择驱动程序为SqlServer,具体操作视所用数据库而定(如果连接为Oracle,建议用Oracle所提供的ODP for .NET,地址:)。

 

C#reportviwer控件<转>_第3张图片

选择数据源后,指定数据库文件,并进行测试,如果连接不通,请检查你的软件设置。

C#reportviwer控件<转>_第4张图片

进行下一步,至显示出库文件内的表及视图,然后打开表,并选择其中的Employees,选择完成。

C#reportviwer控件<转>_第5张图片

在数据源窗口中显示出所选择表及表内的字段,以备使用。

C#reportviwer控件<转>_第6张图片

同时在资源管理器中,也可以看到新增加的数据文件。

C#reportviwer控件<转>_第7张图片

2       报表浏览器

在新建的窗体内,放入报表浏览控件:

C#reportviwer控件<转>_第8张图片

此报表浏览控件集成了报表查看及打印预览的功能,可直接输出至打印机,也可直接输出至Excel文件或PDF文件,对于喜欢看Excel表格的客户来说,这个报表控件非常不错。关于此报表的来源及台前幕后的各种说法,请自己查询相关的网站。

3       建立报表文件

选中报表浏览器控件后,在控件的右上角会出现一个小三角,点击后,出现一个菜单,选择“设计新报表”或在解决方案资源管理器中添加一个新的报表文件:

C#reportviwer控件<转>_第9张图片

双击“报表项”内的“表”,则设计空白表内生成一个表格,我们可以在表格内添加数据项。

C#reportviwer控件<转>_第10张图片

此报表的设计方式类似于MS以前的VB下报表设计环境。在报表设计器中,我将一份报表分为五个部分,从上至下为:报表标题区、列标题区、数据显示区、合计及页脚。如果将报表的设计形式显示出页眉及页脚,报表的形式会看得更清楚些:

选择页眉及页脚:

C#reportviwer控件<转>_第11张图片

显示结果:

C#reportviwer控件<转>_第12张图片

现在开始设计报表:

在“页眉”区内放入一个文本框,将内容更改为“测试报表”,居中,字体放大加粗:

C#reportviwer控件<转>_第13张图片

从数据源窗口中选择合适的列,用鼠标拖到报表内的“详细信息”表格上,数据会自动填入:

C#reportviwer控件<转>_第14张图片

C#reportviwer控件<转>_第15张图片

将设计的报表保存后,返回报表浏览窗口,并为报表浏览器选择我们设计的报表:

C#reportviwer控件<转>_第16张图片

选中报表文件后,菜单也有所改变:

C#reportviwer控件<转>_第17张图片

再为此报表文件指定数据源,选择数据源:

C#reportviwer控件<转>_第18张图片

确定,保存文件并运行测试文件。

4       预览

报表生成后预览如下:

C#reportviwer控件<转>_第19张图片

 

是不是很简单?我们也可以对这个简单的报表进行美化,当然,我加上美化的一些功能后,可能效果更差,但此处只是为了演示用法。

Ø         为数据加表格。

在报表设计器中,选择需要加表格框的区域

C#reportviwer控件<转>_第20张图片

然后在工具栏中选择边框工具

C#reportviwer控件<转>_第21张图片

加什么样的框线根据需要,此处我选择“所有框线”。

C#reportviwer控件<转>_第22张图片

看上去比原来的灰线能稍黑一些,在预览时就能看出来了。

Ø         加打印时间显示

加入一个显示打印时间的文本框,在上面按右键,选属性:

C#reportviwer控件<转>_第23张图片

在“文件框属性”内,选择“值”后面的表达式生成:

C#reportviwer控件<转>_第24张图片

在表达式中选择时间:

C#reportviwer控件<转>_第25张图片

不要忘记表达式的前面一定要有一个“=”,如果没有,手工加上一个。为了更符合我们的习惯,前面可以加个说明,如打印时间等,表达式的写法就要稍做改变:还是以“=”开头,后面加上“打印时间:”,再以“&”连接生成的Now函数即可得到我们想要的样子。

Ø         为行加序号

为了演示,我将序号列加在了表格了最后列

加入一个新的列:

C#reportviwer控件<转>_第26张图片

在显示序号的列中输入相关的值:

C#reportviwer控件<转>_第27张图片

 

在此表达式的后面是Nothing,不是null,不要搞错。

C#reportviwer控件<转>_第28张图片

三项功能已经完成,预览:

C#reportviwer控件<转>_第29张图片

你可能感兴趣的:(port)