国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

在VB中使用水晶報表的一種簡易編程方法

2024-07-21 02:24:03
字體:
來源:轉載
供稿:網友

      水晶報表(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)進行水晶報表開發,可以獲得更大的靈活性。(完)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 兰考县| 车险| 凌云县| 宁国市| 上高县| 吉林省| 略阳县| 正宁县| 油尖旺区| 宁陵县| 雅安市| 龙门县| 温泉县| 阿瓦提县| 聂荣县| 柯坪县| 桐庐县| 庆阳市| 当雄县| 荣昌县| 临安市| 海宁市| 札达县| 三穗县| 察雅县| 达尔| 江孜县| 满洲里市| 工布江达县| 景洪市| 洛隆县| 朝阳县| 班玛县| 柘城县| 舒城县| 剑阁县| 新竹市| 开封县| 衡阳市| 阿拉善右旗| 西丰县|