用户操作
[即时聊天] [发私信] [加为好友]
冯强ID:jhzyz
506932次访问,排名88好友1人,关注者49
企业信息化咨询/移动应用开发
jhzyz的文章
原创 200 篇
翻译 4 篇
转载 24 篇
评论 890 篇
老冯的公告
我的邮箱: feng1973{at}gmail.com

本博客站所有原创文章仅代表个人立场,禁止商业转载或引用,本人保留所有原创文章之一切权益。

博客荣誉

最近评论
Jhzyz:造成中国程序员工资低、技术水平低的原因,其实是盗版,因为有盗版,老板和家户会三天两头要求你换开发工具和平台。。。恶性循环。
SnowGeneral:不管价格如何,要的还是功能的全面可用性,如果盗版内容与正版内容所提过的功能相差无几,我想大多消费者还是会选择价格更便宜的那个
davelv:个人觉得通用软件还是可以做的便宜得~~~毕竟用户众多~~~希望微软的价格做的更适合中国用户(而且美元还贬值了)
leiki_liu:突然发现,在中国根本讲不了理。
hwitsing:我打的到电子市场花10块,买张office的盘5块,再打的回来花10块,吃顿饭50块,总共也就花了75块,199的零头都不到,使用起来也并不比正版的差,这样的价格,我盗版和正版,我会选择哪一个呢?
文章分类
收藏
    相册
    文章附图2008
    友情链接
    2007软件技术英雄会SOA专家
    Drate的随笔(RSS)
    SOA博客圈
    冯强的博客
    又见飞刀-叶开(RSS)
    存档
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

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

    新一篇: 美剧24中的SAP软件 | 旧一篇: 3G八卦之投行看淡

    作者:冯强 发表日期:2005-4-14

    Chinabyte链接:http://soft.yesky.com/SoftChannel/72342371928637440/20050413/1935383.shtml

    或:http://dev.yesky.com/SoftChannel/72342371928637440/20050413/1935383.shtml

    水晶报表(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://dl6.mydown.com/code/more/20050409_Crystal_VB6.rar

     

    发表于 @ 2007年02月09日 14:22:00|评论(loading...)|编辑

    新一篇: 美剧24中的SAP软件 | 旧一篇: 3G八卦之投行看淡

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © 老冯