5

我几乎不熟悉VBA(在学校有过一些课程,就是这样)。现在我需要从 Excel 文件连接到 Oracle 数据库(在远程服务器上运行)。我环顾四周,找到了一些例子。因此,到目前为止,我已经编写了以下代码:

    Sub Try()
         Dim cn As New ADODB.Connection
         Dim rs As ADODB.Recordset
         Dim cmd As ADODB.Command
         Dim chunk() As Byte
         Dim fd As Integer
         Dim flen As Long
         Dim Main As ADODB.Parameter
         Dim object As ADODB.Parameter

     Stil = vbYesNo + vbCritical + vbDefaultButton1
        Titel = "db connection test"
    '   Meldung anzeigen.
        Antwort = MsgBox("trying to connect to db", Stil, Titel, Hilfe, Ktxt)

         ' Connect to the database using ODBC [msdaora][ORAOLEDB.Oracle]Provider=ORAOLEDB.Oracle;
         With cn
             .ConnectionString = "Provider=ORAOLEDB.Oracle;Password=pass;User ID=usr;Data Source=host:port:sid"
             .Open
             .CursorLocation = adUseClient
         End With

         ret = cn.Execute("create table newtesttable (main integer, object oid)")

         ' Here is an example if you want to issue a direct
    ' command to the database
         '
         'Set cmd = New ADODB.Command
         'With cmd
         '    .CommandText = "delete from MYTABLE"
         '    .ActiveConnection = cn
         '    .Execute
         'End With
         'Set cmd = Nothing

         '
         ' Here is an example of how insert directly into the
     ' database without using
         ' a recordset and the AddNew method
         '
         Set cmd = New ADODB.Command
         cmd.ActiveConnection = cn
         ' cmd.CommandText = "insert into newtesttable(main,object) values(?,?)"
         cmd.CommandText = "select * from test"
         cmd.CommandType = adCmdText

         ' The main parameter
        ' Set main = cmd.CreateParameter("main", adInteger, adParamInput)
         'main.Value = 100 '' a random integer value ''
         'cmd.Parameters.Append main

         ' Open the file for reading
         'fd = FreeFile
         'Open "myBlobFile.txt" For Binary Access Read As fd
         'flen = LOF(fd)
         'If flen = 0 Then
          '   Close
           '  MsgBox "Error while opening the file"
            ' End
         'End If

         ' The object parameter
         '
         ' The fourth parameter indicates the memory to allocate
     ' to store the object
       '  Set object = cmd.CreateParameter("object", _
       '                                       adLongVarBinary, _
       '                                       adParamInput, _
                                              flen + 100)
       '  ReDim chunk(1 To flen)
       '  Get fd, , chunk()

         ' Insert the object into the parameter object
       '  object.AppendChunk chunk()
       '  cmd.Parameters.Append object

         ' Now execute the command
         Set rs = cmd.Execute

     '   Mldg = "test"
        Stil = vbYesNo + vbCritical + vbDefaultButton1
        Titel = "asdasdasd"
    '   Meldung anzeigen.
        Antwort = MsgBox(rs, Stil, Titel, Hilfe, Ktxt)
         ' ... and close all
         cn.Close
         Close

 End Sub

我相信这段代码有很多问题,但目前它在尝试执行 .Open 时失败了,也就是说, "Provider cannot be found. It may not be properly installed". 之后我发现我需要下载并安装 ORAOLEDB.dll。我通过安装 ORAOledb11.dll 来做到这一点(我尝试了 32 位和 64 位,你的机器是 64 位的)。我已经通过执行安装了它regsvr32 OraOLEDB11.dll

不幸的是,问题一直存在。那么,解决此问题的步骤是什么?我能以某种方式确保 Oraoledb 正确安装在我的机器上吗?

任何提示将非常感谢。

4

2 回答 2

4

32 位操作系统

通过从 Oracle 官方网站Oracle10g Provider for OLE DB Version 10.1.0.4.0 下载 oracle OLEDB 提供程序,我设法让它在 Windows XP虚拟机上运行。旧操作系统的当前工作链接 OLEDB(32 位)

但请注意,它会将 JDK 和 JRE 替换为较低版本(可以通过配置 xml - products.xml - 我没有足够的心理健康药水来防止它,所以我做了完整安装)。之后您需要删除环境变量中的引用,因为它可能会影响其他程序。安装后,我用regsvc32注册了OraOLEDBxx.dll

我正在使用 excel 2003 连接到 oracle db 11G。:)

连接字符串

我必须启用扩展(ActiveX 数据对象和记录库)。我的函数返回连接是:

Public Function connectToDb(provider As String, host As String, sid As String, user As String, pwd As String, db As String) As ADODB.Connection
Dim conn As ADODB.Connection
Dim dbConnectStr As String

    Set conn = New ADODB.Connection
    If provider = "Oracle" Then
        dbConnectStr = "Provider=OraOLEDB.Oracle;Data Source=" & host & ":1521/" & sid & ";User Id=" & user & ";Password=" & pwd & ";"
    Else

    End If
    conn.ConnectionString = dbConnectStr
    conn.Open
    Set connectToDb = conn
End Function

64 位操作系统但 32 位 Office

当我们的虚拟机迁移到带有Excel 2010的 64 位Windows 7时。确保您将下载ODAC - Oracle 数据访问组件 - 用于您的 excel 安装的正确版本,因为我安装了 32 位 excel 并认为它是 64 位(因为 Windows 是 64 位)所以我正在尝试分娩使其与64 位ODAC 版本一起使用。之后我确实下载了32 位版本,它和以前一样工作。对于安装,只需按照下载的存档文件夹中包含的安装说明进行操作。

Oracle 网站上 ODAC 的当前工作链接

于 2015-10-22T08:01:00.837 回答
0

您可以通过创建一个以.udl结尾的文本文件,然后关闭并打开该文件来确保您的连接字符串是准确的。系统将提示您使用用户界面连接到服务器。输入您的信息并测试连接。然后,如果您的连接正常,请关闭该文件。以文本格式打开该文件并将连接字符串复制到您的代码中。还要确保为 ADO 选择了您的参考库。这一行看起来不对:

Data Source=host:port:sid

下面是我用来从文本中提取 sql 并将结果提取到文本的示例。

 Public Function ObjectConnect(AID As String, APswd As String)

 ObjectConnect = "Provider=ORAOLEDB;Password=" & APswd & ";Persist Security Info=True;User ID=" & AID & ";Data Source=(nameofserverConn)"

 End Function

Sub RunSQL()

Dim strConn As String
Dim Query As String
Dim txt As Object
Dim ns As ADODB.Connection
Dim rs As ADODB.Recordset
Dim txtfile As Object
Dim f As ADODB.Field
Dim myFileSystemObject As Object
Dim txtN As String
Dim DL As String


FName1 = ""
Query = ""
txtStrngX = ""

Set ns = New ADODB.Connection
Set rs = New ADODB.Recordset
ns.ConnectionTimeout = 99000
ns.CommandTimeout = 99000



ns.Open ObjectConnect('UserID', 'Password') 'this is a public function w. userform for people to enter ID and Password.
With rs
    .ActiveConnection = ns
      'however you're writing the sql it would go here.
    .Open Query 
End With


If rs.State <> 0 Then
    DL = Sheet1.Cells(2, 2)
    RecordsetToText rs:=rs, FullPath:=txtN, ValueDelimiter:=DL  'this is a sub function that writes to a text file.  Didn't include the code but left this.  Here you would want to do something with the recordset.
End If

On Error Resume Next
rs.Close
Set rs = Nothing


End Sub
于 2015-03-26T16:19:47.727 回答