机房收费系统(VB.NET)——超详细的报表制作过程

简介: 之前做机房收费系统用的报表是Grid++Report,这次VB.NET重构中用到了VisualStudio自带的报表控件。刚开始当然对这块功能很不熟悉,不过探究了一段时间后还是把它做出来了。 下面把在VisualStudio(我用的是VisualStudio2013,如果与您使用的版本不同,过程中如有不符还请考虑实际情况)中制作报表的过程尽可能详细地记录下来,供初学者学习参考。

       之前做机房收费系统用的报表是Grid++Report,这次VB.NET重构中用到了VisualStudio自带的报表控件。刚开始当然对这块功能很不熟悉,不过探究了一段时间后还是把它做出来了。


      下面把在VisualStudio(我用的是VisualStudio2013,如果与您使用的版本不同,过程中如有不符还请考虑实际情况)中制作报表的过程尽可能详细地记录下来,供初学者学习参考。


       做事要有全局观,先看一下成品,做好的报表如下图:


56.png

       其实能够达到这样的效果需要做两方面的工作:添加报表控件ReportViewer和添加编辑RDLC文件。个人感觉RDLC文件的作用是绑定数据库中需要的数据,ReportViewer则是引用RDLC文件来显示RDLC文件从数据库中绑定的数据。


       1、添加报表控件ReportViewer:

        添加报表控件很简单:工具箱—报表—ReportViewer控件。


       2、添加和编辑编辑RDLC文件:

      添加RDLC文件,有两种方法:1、鼠标左击一下刚刚添加的ReportViewer,会发现控件右上角会出现一个黑色的小三角,点击那个小三角→设计新报表:


57.png


      如果是第一次创建RDLC文件,那么出来的界面是这样的:


58.jpg


        如图片左上角所示,系统默认新建的这个数据集名称为“DataSet1”,为了命名规范,我们先取消“数据源配置向导”这个窗体,重新命名数据集名称,我的命名为DataSetCheckoutReport:

58.png


      命名之后,点击“新建”进入“数据源配置向导”窗口:

59.png


       在“ 应用程序将从哪里获取数据?”问题下,选择“数据库”,下一步:

60.png



       在“ 应用程序将从哪里获取数据?”问题下,选择“数据库”,下一步:

61.png


       在“ 应用程序连接数据库应使用哪个数据库连接? ”后点击“ 新建连接 ”:

62.png


       如上图,分别选择或输入相应项,测试连接,如果测试成功,则确定,自动返回到“ 数据源配置向导 ”窗体,下一步:


       【拓展】


        这个步骤如果您出现了【未能加载文件或程序集“Microsoft.SqlServer.Management.Sdk.Sfc, Version=11.0.0.0, Culture=neutral,PublicKeyToken=89845dcd8080cc91”或它的一个依赖项。系统找不到指定的文件】这个错误,那么可以下载安装 SharedManagementObject.msi 。

63.png


       选择需要用到的数据库中的对象,设置DataSet名称,完成,自动返回“ 报表向导 ”窗体,下一步:

64.png


      将需要的字段按顺序拖入行组或列组中,由于“ 值”中必须拖入字段,这里我们随便拖入一个字段(如果不需要的话后面还可以改),一直点“下一步”,直到“完成”,RDLC文件的雏形就出来了:


65.png


       这里我们不需要用到对每列的sum,所以右键表格的每个行和最后一列不需要的行和列删除,只留下需要的行和列(或者直接把这个表删除,右键插入新的表,然后根据自己的需要编辑),我设计好的表为:

66.png

     第一行为列标题,第二行为数据关联行,即与数据库中数据的关联,鼠标放到第二行每个单元格时,单元格右上角会出现一个小图标,点击则可以为该单元格以及该单元格所在的整列关联数据集中的数据。

     下面就开始设计报表的一些细节,如标题、参数、时间等等:

67.png


       添加文本框:添加标题 “机房收费系统结账单” 其实就是在【工具箱】中加入文本框就可以。其他文本如“开始时间:”、“结束时间:”等也是一样;

       添加内置字段:如上图,右下角的《Exp》就是报表中自带的函数,可以在【报表数据】的内置字段中添加,比如我在右下角的这个Exp就是要显示执行报表的时间,时间格式可以自己设定,右键《Exp》—表达式,在“为以下项设置表达式”下输入表达式即可,如我想让它显示的时间格式为“2014-08-08 08:08:08”,则可输入“ =Format(Now,"yyyy-MM-dd hh:mm:ss") ”;

         添加参数:另外前面带有@的表达式,就是您的程序中将要传入报表中的参数,比如我想在报表左下角显示制作这个报表的操作员,而这个操作员的用户名只能从程序中获取,上面的开始日期@startTime和截止日期@endTime也是需要从代码中传入。这类参数可以右击【报表数据】的“参数”,来添加参数。

    (注:如果您没有找到【工具箱】或【报表数据】那么就需要去【视图】中添加。)

   

      下面就到了最后阶段,加上代码,核心代码为(限于篇幅,在这只贴上刷新按钮事件代码):


'在本代码层首先要添加以下引用
Imports System
Imports Microsoft.Reporting.WinForms


Private Sub btnRefresh_Click(sender As Object, e As EventArgs) Handles btnRefresh.Click
        '根据时间段查询结账记录
        Dim startTime As String = Format(dtpBegin.Value, "yyyy-MM-dd")
        Dim endTime As String = Format(dtpEnd.Value, "yyyy-MM-dd")
        Dim dt As New DataTable
        '对象【checkReportFacade】的【QueryCheckOut】方法功能是根据两个日期,查询此时间段的结账记录
        dt = checkReportFacade.QueryCheckOut(startTime, endTime)
        '声明一个报表数据源对象
        Dim rptDateSource = New ReportDataSource
        '设置报表数据集名称
        rptDateSource.Name = "DataSetCheckoutReport"
        '设置报表数据源实例
        rptDateSource.Value = dt
        '设置嵌入报表的资源名称
        reportViewer.LocalReport.ReportEmbeddedResource = "UI.CheckReport.rdlc"
        '清空报表数据源
        reportViewer.LocalReport.DataSources.Clear()
        '添加报表数据源
        reportViewer.LocalReport.DataSources.Add(rptDateSource)
        '设置报表中的参数集合(注意:这里的参数和报表中的参数大小写和数据类型都要一致)
        Dim strUserID As String = Entity.UtilUserEntity.UtilUser.UserID
        Dim params As ReportParameter()
        params = {New ReportParameter("startTime", startTime),
                  New ReportParameter("endTime", endTime),
                  New ReportParameter("userId", strUserID)}
        '传递报表中的参数集合
        reportViewer.LocalReport.SetParameters(params)
        '刷新报表
        Me.reportViewer.RefreshReport()
    End Sub


             温馨提示:代码中的数据集名称DataSetCheckoutReport一定要与刚开始创建RDLC文件时设定的数据集名称DataSetCheckoutReport一样,否则将会出现“尚未为数据源***提供数据源实例”的错误。

      最后,重新单击第一步添加的ReportViewer空间,点击右上角的小三角,在“选择报表”后选择您刚制作的报表就大功告成了。到此,一张简单的报表就制作好了

     

      如果步骤中有错误或不全面的地方,欢迎补充说明。


相关文章
|
8月前
|
前端开发 JavaScript 关系型数据库
.NET开源、强大的Web报表统计系统
.NET开源、强大的Web报表统计系统
168 0
|
SQL 存储 缓存
机房重构系列——ADO.NET访问数据库
机房重构系列——ADO.NET访问数据库
113 0
|
SQL 数据库连接 数据库
【vb.net机房收费系统】之sqlhelper
【vb.net机房收费系统】之sqlhelper
47 0
【vb.net机房收费系统】之没有包含要从继承的组件的已生成程序集
【vb.net机房收费系统】之没有包含要从继承的组件的已生成程序集
48 0
|
BI vr&ar
ActiveReports工作总结4——换页打印(.NET下的报表)
vs2005+ActiveReportsNet2 AR下载地址:ftp://ftp.datadynamics.com/    本节目标: 有如下数据源最终希望打印成如下(按班级进行分页):         1,先准备如下数据:         2,创建一个AR模版,大致布局与控件如下图: GroupHeader中放入一个TextBox:CurrentClass,该控件希望显示当前页打印的Class。
777 0
|
存储 SQL 数据库连接
机房收费系统(VB.NET)——存储过程实战
最初接触存储过程是在耿建玲老师的视频里,当初只是草草过了一遍,只是有了个印象,知道了这个名词;大二时也有SqlServer数据库这门课,不过老师没讲,自己也没看;真正对存储过程的了解来自于自学考试中的《数据库系统原理》,在考试中,知道存储过程是干嘛的,在纸上怎么写,但从来没有在DBMS中亲手敲过。于是机房收费系统给了我这个机会。 在这里不再过多叙述关于存储过程德基本知识,只写一下在机房收费系统这个小项目中是如何用到存储过程的。
机房收费系统(VB.NET)——存储过程实战
SAP MM ME81N PO Value Analysis报表中Net Value 为负数是怎么回事?
SAP MM ME81N PO Value Analysis报表中Net Value 为负数是怎么回事?
SAP MM ME81N PO Value Analysis报表中Net Value 为负数是怎么回事?
|
SQL 安全 数据可视化
.NET Core开发的iNeuOS工业互联网平台,发布 iNeuDA 数据分析展示组件,快捷开发图形报表和数据大屏
经过一段时间的努力,iNeuDA产品组件已经开发和测试完成,现在正式上线。现在iNeuOS工业互联网操作系统的技术体系和产品体系更佳完善,为中小企业提供更佳全面解决方案。
463 0
.NET Core开发的iNeuOS工业互联网平台,发布 iNeuDA 数据分析展示组件,快捷开发图形报表和数据大屏
|
SQL BI 开发框架
RDIFramework.NET V3.3 Web版新增报表管理功能模块-重量级实用功能
在RDIFramework.NET V3.3 Web版本新增了全新的报表管理功能模块,非常实用的功能,重量级推荐。主要用于对日常常用的报表做定制展示。可以自动发布到模块(就可授权给指定资源访问),在报表定义主界面可以同时对定义好后报表预览效果,支持多种报表样式(如:折线图、柱状图、饼图、地图)等,每种报表样式都给出了参考定义的语句,支持直接在线打印。
1364 0
|
Web App开发 前端开发 .NET
Visual Studio 2017 集成Crystal Report为ASP.NET MVC呈现报表
原文:Visual Studio 2017 集成Crystal Report为ASP.NET MVC呈现报表 最近项目需要实现报表功能,平衡各方面的因素,还是使用Crystal Report(水晶报表) To get there click here: Download WIKI https://www.
3533 0

相关实验场景

更多