在vb中动态加载水晶报表rpt文件的方法
2005-01-30 12:33
489 查看
这个问题在很多论坛里边都有问到。但是一直没找到满意的答案。下边写出一个解决办法
Dim sql As String
Dim rstLiuShui As New ADODB.Recordset
Dim Rpt As New CRAXDDRT.Report
Dim PrintApp As New CRAXDDRT.Application
If Option2.Value = True Then
sql = "select * from n_ihbill where datediff(d,日期,'" & Format(DTPicker1.Value, "yyyy-MM-dd") & "')=0 and 住院号=" & cbopatient.ItemData(cbopatient.ListIndex)
Else
sql = "select * from n_ihbill where datediff(d,日期,'" & Format(DTPicker1.Value, "yyyy-MM-dd") & "')=0"
End If
Debug.Print sql
rstLiuShui.Open sql, adoconn, adOpenForwardOnly, adLockReadOnly
If rstLiuShui.EOF And rstLiuShui.BOF Then
MsgBox "没有可用数据!", vbInformation
Exit Sub
End If
Set Rpt = PrintApp.OpenReport("cryliushui.rpt")
Rpt.Database.SetDataSource rstLiuShui
Call viewReport(Rpt, "", "打印流水")
rstLiuShui.Close
Set rstLiuShui = Nothing
这样就可以实现程序与报表的逻辑分离。如果用报表设计器。每次更改报表格式都需要编译程序。客户甚至可以自己更改报表格式。
Dim sql As String
Dim rstLiuShui As New ADODB.Recordset
Dim Rpt As New CRAXDDRT.Report
Dim PrintApp As New CRAXDDRT.Application
If Option2.Value = True Then
sql = "select * from n_ihbill where datediff(d,日期,'" & Format(DTPicker1.Value, "yyyy-MM-dd") & "')=0 and 住院号=" & cbopatient.ItemData(cbopatient.ListIndex)
Else
sql = "select * from n_ihbill where datediff(d,日期,'" & Format(DTPicker1.Value, "yyyy-MM-dd") & "')=0"
End If
Debug.Print sql
rstLiuShui.Open sql, adoconn, adOpenForwardOnly, adLockReadOnly
If rstLiuShui.EOF And rstLiuShui.BOF Then
MsgBox "没有可用数据!", vbInformation
Exit Sub
End If
Set Rpt = PrintApp.OpenReport("cryliushui.rpt")
Rpt.Database.SetDataSource rstLiuShui
Call viewReport(Rpt, "", "打印流水")
rstLiuShui.Close
Set rstLiuShui = Nothing
这样就可以实现程序与报表的逻辑分离。如果用报表设计器。每次更改报表格式都需要编译程序。客户甚至可以自己更改报表格式。
相关文章推荐
- 水晶报表中如何动态加载图片(图片文件版本及数据库版本)
- 解决水晶报表中动态加载的图片或利用水晶报表创建的图表不显示图片的方法
- 水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
- 水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
- 水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
- 【水晶报表之图片篇-a】 动态加载图片(图片文件版本及数据库版本)
- 水晶报表中如何动态加载图片(图片文件版本及数据库版本)
- [转]水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
- 水晶报表中如何动态加载图片(图片文件版本及数据库版本)
- 【水晶报表之图片篇-a】 动态加载图片(图片文件版本及数据库版本)
- 水晶报表中如何动态加载图片(图片文件版本及数据库版本)
- 【水晶报表之图片篇-a】 动态加载图片(图片文件版本及数据库版本)
- 水晶报表中如何动态加载图片(图片文件版本及数据库版本)
- 水晶报表 文件 xxxx{354234-523432-5235-325-2523}.rpt 文件内部出错:无法加载数据解决方案
- 水晶报表的宽度调整方法(设计器、代码调整、rpt文件属性)
- VS2005-VS2008或VS2010水晶报表未能加载文件或程序集
- 倒入水晶报表 RPT文件
- jquery及js实现动态加载js文件的方法
- jquery动态加载javascript文件的方法
- js加载之使用DOM方法动态加载Javascript文件