首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程
在VB中使用水晶报表的一种简易编程方法-.NET教程,VB.Net语言
作者:网友供稿 点击:52
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

作者:冯强

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

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

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

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


第一步:
在vb工程中project菜单加入"add crystal report 9",报表名使用默认即可。这时form2(crystal rerport自动添加的form,假设名为form2)被自动分配了如下代码:

option explicit
dim report as new cystal1

private sub form_load()

screen.mousepointer = vbhourglass 调用水晶报表时置鼠标为沙漏状

crviewer91.reportsource = report 该语句的赋值将在后面被修改

crviewer91.viewreport
screen.mousepointer = vbdefault 调用水晶报表完成后置鼠标为默认形状

end sub

private sub form_resize()

crviewer91.top = 0
crviewer91.left = 0
crviewer91.height = scaleheight
crviewer91.width = scalewidth

end sub

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

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

public conn as new adodb.connection
public rs as new adodb.recordset

第四步:
关于vb程序的ado数据库连接注意事项,请看下面的打印按钮例程。

private sub command1_click()

dim connstr as string

if conn.state = adstateopen then conn.close

connstr = "provider=microsoft.jet.oledb.4.0;data source=" & app.path & "\prtest.mdb;persist security info=false" prtest.mdb是程序当前目录的测试access数据库

conn.connectionstring = connstr

conn.open

conn.cursorlocation = aduseclient

if rs.state = adstateopen then rs.close

rs.open "test", conn, adopenkeyset, adlockreadonly

report.database.setdatasource rs, 3, 1 此行取消

form2.show 1 数据库连接完成后,调用form2水晶报表工程


end sub

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

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

option explicit
dim report as new cystal1
上面一行取消

private sub form_load()

dim oapp as new craxdrt.application
dim orpt as craxdrt.report
dim reportname as string
上面三行是新增加的

screen.mousepointer = vbhourglass


reportname = "\rpt\pr1.rpt"   定义要引用的rpt文件

set orpt = oapp.openreport(app.path & reportname, 1)

orpt.database.setdatasource rs 连接水晶报表和数据源
orpt.readrecords

crviewer91.reportsource = orpt 启用水晶报表的预览功能

crviewer91.viewreport
screen.mousepointer = vbdefault


end sub

private sub form_resize()

crviewer91.top = 0
crviewer91.left = 0
crviewer91.height = scaleheight
crviewer91.width = scalewidth

end sub

private sub form_unload(cancel as integer)

set report = nothing

set rs = nothing

set conn = nothing

unload form2

end sub

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

源码下载:


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·使用windows脚本入侵WINDOWS服务器-网管专栏,网络技术
·清除网页历史记录-ASP教程,ASP应用
·在java中利用动态编译实现eval-JSP教程,Java技巧及代码
·如何制作Asp.Net界面模板-.NET教程,Asp.Net开发
·C#实现的18位身份证格式验证算法-.NET教程,数据库应用
·如何用PHP发电子邮件(1)-PHP教程,邮件处理
·Java 中的 XML:Java 文档模型的用法-JSP教程,Java与XML
·如何更新父窗体-.NET教程,Asp.Net开发
·用Windows 2003实现软RAID-网管专栏,操作系统
·使用Magic Winmail Server轻松架设邮件服务器(五)-网管专栏,邮件服务
最新文章
·photoshop让花卉照片更加清晰嫩绿_photoshop教程
·论c#变得越来越臃肿是不可避免的_c#应用
·杜少军:行走在网络世界的奇才_站长访谈
·教你用photoshop外插滤镜做卷页效果_photoshop教程
·通过dreamweaver设计网页时组织css的建议_dreamweaver教程
·草根网站比门户网站更有前途_站长心得
·如何针对google进行网站优化_google推广
·google推“我的搜索历史”测试版 提高个性化搜索竞争力_google推广
·八大要领 做网站就这么简单2_站长心得
·关闭widnows vista偷偷共享的文件_windows vista
相关主题
  • 在vb中使用udp协议_visualbasic教程
  • 在vb中使用文件对象_visualbasic教程
  • 在vb中使用水晶报表的一种简易编程方法_visualbasic教程
  • 在VB中使用水晶报表的一种简易编程方法-.NET教程,报表/图形/Office
  • 在VB中使用IE的 WebBrowser控件改进界面设计-.NET教程,VB.Net语言
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭