rpt水晶报表制作过程
原文:rpt水晶报表制作过程
最近公司安排一个以前的项目,里面需要用到水晶报表,由于原来做这个项目的同事离职,所在公司的同事报表做成了rdlc类型的,而这类报表在加载的时候很难动态的从数据库加载数据,问同事也说不出个所以然,这可怎么办?项目总不肯能不做吧?没办法只能查找rpt文件制作的办法,原来的微软自带的rdlc类型的报表做出来的样式很难满足需求,rdlc类型的报表如图(个人第一次做rpt类型的文件,难免有错误,欢迎指正):
我自己也从未做过报表,刚开始用vs不能正常打开原有的rpt文件,打开后全是二进制类型的乱码,上网百度了一下,没找到一个完整的解决办法(大多都说的比较抽象),只是看到大伙都在说vs2010后的版本就没有提供CrystalReport这个功能,后来看到一个论坛里的一个大哥说要下载CrystalReport这个插件,然后找了一个版本CRforVS_13_0_5下载安装关闭vs后再重新打开vs新建报表就果真看到了Crystal Report,大家应该都注意到了vs2012并没有rpt类型的CrystalReport这个类型的报表,需要安装CrystalReportForVs这个插件,建议下载CRforVS_13_0_5这个版本,下载地址:http://downloads.businessobjects.com/akdlm/cr4vs2010/CRforVS_13_0_5.exe
安装完成后,务必要关闭vs,然后在打开vs2012,vs2013版本我没安装所以不知道是否可以,按说是没有问题的,因为我安装的Crystal Report上面显示是支持vs2010,但实际是我安装的vs2012也支持。
好了废话不多说,安装CRforVS插件时如果你的系统是64位的,CRforVS安装完成后会自动提示你是否安装64位的,点击“是”即可,由于安装的时间比较长我就不在这儿截图演示了安装过程了,安装成功后,找到右边的解决方案资源管理器,选择你要新建.rpt文件的项目,右键项目目录,选择新建项,弹出一个添加新项的对话框,点击左侧的Reporting然后就可以看到右边多出来一个Crystal Report项,如图:
点击添加,弹出如下对话框:
从上图可以看出创建CrystalReport有三种创建方法:使用报表向导导,这种方式通常是新建模板时使用,点击确认后新建的rpt文件是一个包含报表头,页眉,详细资料,报表尾,页脚的空模板,里面什么都没有,需要自己来创建样式和内容,如果选择来自于现有的报表则会弹出来一个文本选择路径的对话框,找到要作为样板的rpt文件,点击确定即可创建一个原有模板的报表,而且里面的字段数据不会丢失。
我们选择“来自于现有的模板”,其他两种基本制作方法一样大同小异,创建成功后会生成一个原有报表的界面,如图:
,另外我们的工具箱也会有一个Crystal Reports还会多一个字段资源管理器,如图:
我们接下来就是要为报表添加数据源,在左侧或者“视图->其他窗口->数据源”,选择添加新数据源,会弹出如下图:
单击下一步,会弹出:
再单击下一步
选择”新建连接”
填好服务器名,选择好数据库,测试连接没问题的话,单击确定,会回到刚才的窗口,单击下一步,弹出:
选择好你要添加的表或者存储过程,起一个DataSet的名称,单击完成,左侧数据源就会多出我们刚才添加的数据源(如果没有就刷新下)
接下来隐藏数据源,不用再管它,回到报表窗口,
然后我们可以添加文本,例如我们在报表的页眉部分添加一个公司名,在报表上右键“插入”,选择“文本对象”鼠标上会出现一个文本框,我们把这个文本框放到我们想要的地方,给他命名为:“公司名称:”,(也可以插入文本文件,单击文本框,右键选择“自文本插入”,选择要读取的文件即可),右键空白处,选择数据库专家,弹出对话框
最后单击确定(注意一般右侧只能有一个表),
接下来,我们在字段资源管理器中选择我们要放到报表中的字段,如图我们选择companyName字段
报表图中如图(其他字段一样):
好了,报表基本制作完成,现在就创建一个WinForm窗体,窗体创建好后,找到左侧工具栏里面的ReportViewer控件,拖到窗体上,我们的窗体会变成:
如果我们的窗体弹出如下异常,我们就要删除引用里面的画线部分的类库:
接下来我们就是写代码了,
双击在Load事件中写入如下代码:
Public Shared Function Query(ByVal SQLString As String) As DataSet
Using connection As New SqlConnection(connectionString)
Dim ds As New DataSet()
Try
connection.Open()
Dim command As New SqlDataAdapter(SQLString, connection)
command.Fill(ds, "ds")
Catch ex As System.Data.SqlClient.SqlException
Throw New Exception(ex.Message)
End Try
Return ds
End Using
End Function
Private Sub FrmReport_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Dim sql As String
sql=”select * from outstoragebill” ‘注意这里的sql语句中的列名必须和上面我们创建的字段管理器中的列名相同
Dim ds As DataSet = DbHelperSQL.Query(sqlstr)
Dim count As Int32 = ds.Tables(0).Rows.Count
For i = 1 To 9 - (count Mod 9)
ds.Tables(0).Rows.Add(New Object() {""})
Next
Dim rpt As New CrystalReport1()
'rpt.Load(Application.StartupPath & "RptOutstorage.rpt")
rpt.Load(Application.StartupPath & "../ CrystalReport1.rpt")’这里的‘CrystalReport1是我们刚刚创建的报表名,到此水晶报表制作完成
rpt.SetDataSource(ds.Tables(0))
CrystalReportViewer1.ReportSource = rpt
End Sub
完成后如图所示:
rpt水晶报表制作过程的更多相关文章
- 机房收费系统(VB.NET)——超具体的报表制作过程
之前做机房收费系统用的报表是Grid++Report,这次VB.NET重构中用到了VisualStudio自带的报表控件. 刚開始当然对这块功能非常不熟悉,只是探究了一段时间后还是把它做出来了. 以下 ...
- winform,水晶报表制作
1.安装最新的 SP:(SP 29 示例 – https://origin.softwaredownloads.sap.com/public/file/0020000001636412020) 2.新 ...
- Visual Studio 2012使用水晶报表Crystal Report
原文:Visual Studio 2012使用水晶报表Crystal Report SAP在 2013年1月14日 released SAP Crystal Reports,developer ver ...
- asp.net core使用水晶报表问题
背景 最近项目上遇到一个需求,要后台通过定时任务把水晶报表生成pdf文件,然后邮件发送给相关人. 技术实现思路 选用ASP.NET Core框架(基于2.2版本),通过IHostedS ...
- 水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
水晶报表的宽度调整方法(设计器.代码调整.rpt文件属性) Posted on 2010-08-07 23:52 moss_tan_jun 阅读(1725) 评论(0) 编辑 收藏 经过个人反复研究后 ...
- 用stimulsoft Reports报表工具制作简单报表的过程
这是在数据库sql server中People表的数据
- SAP B1:水晶报表中用Code128制作条型码的方法
一.在[文件系统]中新建一个[Fonts文件夹],然后添加[Code128.ttf]文件. 二.在水晶报表里的[字段资源管理器]的[公式字段]中新建一个公式字段.点击[使用编辑器]之后弹出[公式工作室 ...
- 水晶报表中用Code128制作条型码的方法
一.在[文件系统]中新建一个[Fonts文件夹],然后添加[Code128.ttf]文件. 二.在水晶报表里的[字段资源管理器]的[公式字段]中新建一个公式字段.点击[使用编辑器]之后弹出[公式工作室 ...
- [转]VS2010中水晶报表安装应用及实例
基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Visual Studio Team Syst ...
随机推荐
- QR代码简单
QR代码(Quick Response Code, 高速响应码)属于二维矩阵码在一个.由DENSO(日本电装)公司开发,由JIS和ISO将其标准化. QR码分为两种模式:模式1.模式2.当中.模式1相 ...
- boostrap-非常好用但是容易让人忽略的地方------Font Awesome
font-awesome基本用法 官方代码传送门 font-awesome在bootstrap中的特殊用法(这个才是重点) 要点归纳1(官方) 官方代码传送门 要点归纳2(我的) <a href ...
- UVa 208 - Firetruck 回溯+剪枝 数据
题意:构造出一张图,给出一个点,字典序输出所有从1到该点的路径. 裸搜会超时的题目,其实题目的数据特地设计得让图稠密但起点和终点却不相连,所以直接搜索过去会超时. 只要判断下起点和终点能不能相连就行了 ...
- Docker安装应用程序(Centos6.5_x64)
Docker安装应用程序(Centos6.5_x64) Authoer::jom_ch@2014/7/23 Docker官方网站 http://www.docker.com/ 一,安装EPEL 关于E ...
- Docker contanier comunication with route
2台宿主机,hslave1 192.168.1.153, hslave2 192.168.1.154 修改网段 docker0默认网段是172.17.0.0/16,修改154机器的docker0的网段 ...
- dojo/dom源码
dojo/dom源码学习 dojo/dom模块作为一个基础模块,最常用的就是byId方法.除此之外还有isDescendant和setSelectable方法. dom.byId(myId)方法: ...
- bootstrap之Click大事
上一篇文章中谈到了bootstrap流程,本文开始把目光bootstrap它可以接受指令(从源代码视图的透视.因为appium该项目现在还处于不断更新,因此,一些指令已经实现.也许未来会实现一些.从视 ...
- MYSQL-用户权限的验证过程(转)
知识点 因为MySQL是使用User和Host两个字段来确定用户身份的,这样就带来一个问题,就是一个客户端到底属于哪个host. 如果一个客户端同时匹配几个Host,对用户的确定将按照下面的优先级来排 ...
- Light OJ 1341 Aladdin and the Flying Carpet Pollard_rho整数分解+DFS
进入a b 多少努力p, q 使p*q == a && p < q && p >= b 直接大整数分解 然后dfs所有可能的解决方案劫持 #include ...
- 使用Eclipse+Maven+Jetty构建Java Web开发环境(几个教程综合集成2014发行)
工作需要使用Jetty由于web集装箱,得知Eclipse+Maven+Jetty该组合是非常好的,因此,要在网上找了很多教程,但不写或多或少特定的或过时的内容而导致最终的配置失败,易于配置为未来的同 ...