0

我是水晶报表的新手。我必须在运行时通过代码设置报表的数据源。我有一个工作代码,但它是非常不可预测的,并且一直存在很多问题。我只是想知道我是否做错了什么,或者是否有更好的方法来做到这一点。

有时我觉得报告甚至没有使用连接字符串,而是使用在独立 Crystal 应用程序的报告编译时指定的连接。这是真的?

 Dim connectionInfo As New ConnectionInfo

        connectionInfo.ServerName = "UID=abc;PWD=abc;Driver= {SQL Server};Server=" & Page.Request.QueryString("server") & ";Database=" & Page.Request.QueryString("database")

 Using report As New ReportDocument
            report.Load(Server.MapPath("/report/Crystal/test.rpt"))
            report.FileName = Server.MapPath("/report/Crystal/test.rpt")

            SetDBLogonForReport(connectionInfo, report)
...
 End Using

   Private Sub SetDBLogonForReport(ByVal connectionInfo As ConnectionInfo, ByVal reportDocument As ReportDocument)

        Dim tables As Tables
        tables = reportDocument.Database.Tables

        For Each table As CrystalDecisions.CrystalReports.Engine.Table In tables

            Dim tableLogonInfo As New TableLogOnInfo

            tableLogonInfo = table.LogOnInfo
            tableLogonInfo.ConnectionInfo = connectionInfo
            table.ApplyLogOnInfo(tableLogonInfo)

        Next


    End Sub
4

1 回答 1

2

不久前有人问过这个问题,但我想我会在这里发布回复,以防其他人正在寻找答案。我刚刚使用了上面的代码,它工作得很好......除了一些例外。

我变了:

connectionInfo.ServerName = [Entire ConnectionString?]

到:

connection.DatabaseName = [DatabaseName]
connection.UserID = [UserID]
connection.ServerName = [ServerName]
connection.Password = [Password]

此外,不需要tableLogonInfo将循环中的变量初始化为。New TableLogOnInfo

我敢肯定,正如上面评论中提到的那样,那里有很多例子。我只是想我会在这里添加一个答案,因为这是我在寻找解决方案时得到的第一个结果。

于 2012-10-12T08:34:49.457 回答