网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Visual Basic
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.VB中不规则图形热点的实现.
.在数据库中不用EOF以加快记录循环.
.将ENTER变成TAB键.
.从文件中提取图标.
.VB中用第三方控件打造QQ菜单.
.VB访问数据库的方案比较.
.用VB设计VCD播放器的方法与技巧.
.在VB中实现闪动标题栏.
.VB如何将DBgrid印出来.
.在VB中控制Word.
.VB应用程序访问SQLServer方法探讨.
.VB编程的几个API函数的应用问题.
.用VB实现用户登录admin888的修改.
.Sql Server中Image类型字段在VB..
.认识一下VB6.0的编程环境.
.解决VisualBasic非正常退出一例.
.如何获得系统光驱的盘符.
.按下某组键(HotKey)便执行某程式.
.数据报表设计器在多层结构开发的.
.如何通过VB获取网卡地址.

在VB中使用水晶报表的一种简易编程方法

发表日期:2006-2-27


水晶报表(CrystalReport)是业内最专业、功能最强的报表系统,它除了强大的报表功能外,最大的优势是实现了与绝大多数流行开发工具的集成和接口。在VS.Net平台做过报表开发的程序员,一定都对水晶报表强大、高效、集成等特性留下了深刻印象。除了开发新程序外,在工作中我们常需要接触到很多较早的软件系统报表功能升级的需求,如果能结合水晶报表这一强大的工具,往往能事半功倍。

  VB是以前流行的数据库开发平台,用其开发的C/S系统在社会上有非常大的保有量,但VB超弱的报表功能往往让程序员面对客户的升级要求一筹莫展。本文并不做水晶报表的使用和编程教学,实际上水晶报表本身的使用方法和VS.Net平台并没有太大的差别,我主要是和大家探讨一下VB和水晶报表的一种较方便的接口方式。我的开发测试平台是Windows2003Standard简体中文版、VB6.0 sp5英文版、Crystal9.0简体中文开发版。

  关于在水晶报表中制作报表模板的方法,并非本文的探讨范围,读者可以参考CrystalReport的帮助文件和官方网站的技术资料。简单得说,首先要通过水晶报表的数据库引擎手动连接相应的表结构,制作报表模板,并保存为rpt文件,该项操作和利用VB自带的报表工具制作报表大同小异。

  简单地说,用VB调用水晶报表进行报表开发的简单接口方法就是,在水晶报表中用"仅字段定义"来获得字段分布文件,用虚拟的文件创建表字段,用CRAXDRT对象来强制改变数据源(ADO.recordset),其效果相当于在VB中调用了rpt文件。下面分步骤介绍编程方法。

  第一步:

  在VB工程中Project菜单加入"AddCrystalReport9",报表名使用默认即可。这时Form2(Crystal Rerport自动添加的Form,假设名为Form2)被自动分配了如下代码:

->OptionExplicit
dimReportasNewCystal1

PrivateSubForm_Load()

 Screen.MousePointer=vbHourglass
 '调用水晶报表时置鼠标为沙漏状CRViewer91.ReportSource=Report'该语句的赋值将在后面被修改

 CRViewer91.ViewReport
 Screen.MousePointer=vbDefault'调用水晶报表完成后置鼠标为默认形状

EndSub

PrivateSubForm_Resize()

 CRViewer91.Top=0
 CRViewer91.Left=0
 CRViewer91.Height=ScaleHeight
 CRViewer91.Width=ScaleWidth

EndSub->

  第二步:

  点击CrystalReport设计器的"数据库字段",选定"数据库专家…",然后点"创建新连接",再点"仅字段定义",创建"数据库定义"文件,字段名和宽度和原数据库表保持一致。最后,在数据库字段中获得了相应字段,将其置于报表上,按水晶报表的要求配置。
  第三步:

  该步骤非常关键,添加一个Modual到工程文件中,定义全局的ADODB变量,实现数据库和水晶报表的动态连接。代码如下:

->PublicconnAsNewADODB.Connection
PublicrsAsNewADODB.Recordset->

  第四步:

  关于VB程序的ADO数据库连接注意事项,请看下面的打印按钮例程。

->PrivateSubCommand1_Click()

 DimconnstrAsString

 Ifconn.State=adStateOpenThenconn.Close

  connstr="Provider=Microsoft.Jet.OLEDB.4.0;DataSource="&App.Path&"\prtest.mdb;PersistSecurityInfo=False"'prtest.mdb是程序当前目录的测试Access数据库

  conn.ConnectionString=connstr
  conn.Open
  conn.CursorLocation=adUseClient

  Ifrs.State=adStateOpenThenrs.Close
   rs.Open"test",conn,adOpenKeyset,adLockReadOnly
   'Report.Database.SetDataSourcers,3,1
   Form2.Show1'数据库连接完成后,调用Form2水晶报表工程
EndSub->

  需要提请大家注意的是,上面代码中的Report.Database.SetDataSourcers,3,1是初用水晶报表的程序员容易犯的错误,使用该语句后将造成数据库和水晶报表的连接失败。如何动态调用水晶报表呢?请看第四步。

  第五步:

  创建水晶报表和数据库数据源的连接,需要修改上面Form2的代码。

->OptionExplicit
'dimReportasNewCystal1
'上面一行取消

PrivateSubForm_Load()

 DimoAppAsNewCRAXDRT.Application
 DimoRptAsCRAXDRT.Report
 DimreportNameAsString
 '上面三行是新增加的

 Screen.MousePointer=vbHourglass
 reportName="\rpt\Pr1.rpt"  '定义要引用的rpt文件

 SetoRpt=oApp.OpenReport(App.Path&reportName,1)

 oRpt.Database.SetDataSourcers'连接水晶报表和数据源
 oRpt.ReadRecords

 CRViewer91.ReportSource=oRpt'启用水晶报表的预览功能

 CRViewer91.ViewReport
 Screen.MousePointer=vbDefault

EndSub

PrivateSubForm_Resize()

 CRViewer91.Top=0
 CRViewer91.Left=0
 CRViewer91.Height=ScaleHeight
 CRViewer91.Width=ScaleWidth

EndSub

PrivateSubForm_Unload(CancelAsInteger)

 'SetReport=Nothing

 Setrs=Nothing
 Setconn=Nothing
 UnloadForm2
EndSub->

  上面介绍了在VB中使用水晶报表进行报表开发的一种方法,该方法简单易用,适合初学者上手。大家熟悉以后,还可以继续学习CrystalReport提供的API函数(Lib库 Crpe32.dll)进行水晶报表开发,可以获得更大的灵活性。->

上一篇:关于VisualBasic6.0类开发(下) 人气:3542
下一篇:VB中访问存储过程的几种办法 人气:4360
浏览全部Visual Basic的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐