gpt4 book ai didi

database - 连接到 Sybase 数据库的 VBScript 错误 - 找不到提供程序

转载 作者:搜寻专家 更新时间:2023-10-30 23:03:24 24 4
gpt4 key购买 nike

我正在编写连接到 Sybase 数据库的 VBScript,从表中读取一些数据并将其存储在变量中,然后连接到 MS SQL 服务器并将数据插入到具有先前存储的变量数据的表中。

我找到了一些现有的脚本来帮助我前进 herehere .

我理解这些就好了。唯一的问题是数据库连接字符串本身。这是当前正在使用的连接字符串。 (我在实际脚本中使用了正确的值,但出于安全目的在此处更改了一些值)

Provider=Sybase.ASEOLEDBProvider.2;Driver={SYBSE ASE ODBC Driver};Data Source=MyDataSource;Port=1234;Database=MyDatabase;uid=MyUser;pwd=MyPassword

但它导致了错误:找不到提供者。它可能没有正确安装。

以下是您可能需要确定问题原因的一些系统信息:

  • 脚本将在 64 位 Windows 7 机器上运行
  • 我已使用 MS Access 成功连接到此 Sybase 数据库
  • 我已经安装了 Sybase ASE ODBC 驱动程序(32 位)版本 03.50.0010
  • 我已通过转至 C:\Windows\SysWOW64\odbcad32.exe 并在其中找到驱动程序来确认它已安装并正常工作
  • 数据库是系统 DSN(不是用户 DSN)
  • Sybase Open Client 版本 10.0.4

问题似乎与连接字符串的 Provider= 部分有关。这里值得注意的是,一旦我去掉 Provider= 部分,我就会收到此错误:指定的 DSN 包含驱动程序和应用程序之间的体系结构不匹配。所以这让我相信这里存在 32 位和 64 位不匹配。我对此进行了研究,结果发现修复它的方法是将 Provider= 添加到您的连接字符串中,以某种方式指定要使用的连接字符串。这是我在连接字符串中尝试过的提供程序列表:

  • Sybase ASE OLE DB 提供程序
  • Sybase.ASEOLEDBProvider
  • ASEOLEDB
  • ASEOLEDB.1
  • Sybase.ASEOLEDBProvider.2
  • 赛贝斯
  • 优势 OLE DB 提供商

所有这些都抛出相同的错误。我在这里错过了什么?


编辑:根据您的建议,我对脚本进行了一些修改,并且能够克服最初的错误,但现在我得到了一个完全不同的错误。这是现在的脚本

Dim connStr, objConn

DataSource = "ICCM_PREVIEW"
ServerIP = "1.2.3.4"
Port = "1234"
DBuser = "myUser"
DBpwd = "myPassword"
DBName = "myDatabase"
Driver = "SYBASE ASE ODBC Driver"

connStr = ""
connStr = connStr &"Driver="& Driver &";"
connStr = connStr &"Data Source="& DataSource &";"
connStr = connStr &"Srvr="& ServerIP &","& Port &";"
connStr = connStr &"Database="& DBName &";"
connStr = connStr &"uid="& DBuser &";"
connStr = connStr &"pwd="& DBpwd &";"

Wscript.Echo connStr

'Define object type
Set objConn = CreateObject("ADODB.Connection")

'Open Connection
objConn.open connStr

这是我现在收到的错误消息,但我不知道如何解决这个问题:

Microsoft OLE DB Provider for ODBC Drivers: [SYBASE][ODBC Sybase driver][Sybase]ct_connect(): user api layer: internal Client Library error: HAFAILOVER:Trying to connect to server

最佳答案

您已经为 sybase 安装了 32 位 ODBC 驱动程序,但您打算在 64 位机器上运行它。您要么还需要安装 64 位驱动程序,要么需要在 32 位模式下运行 vbscript。

您可以在此处阅读如何在 32 位模式下运行 vbscript:How do I run a VBScript in 32-bit mode on a 64-bit machine?

编辑添加:如果您尝试在 32 位模式下运行 vbscript,请确保将 provider= 位从您的连接字符串中删除。

同时添加:与 provider= 位相关。您正在使用 ODBC 驱动程序,但您尝试添加到连接字符串中的提供程序是 OLEDB 提供程序。我很确定您不能在同一连接字符串中混合和匹配 OLEDB 和 ODBC,因为它们是不同的技术。另一个建议是为 sybase 安装 64 位 OLEDB 驱动程序并使用使用该驱动程序的 OLEDB 连接字符串。

最后,有几个选项,但在您的驱动程序和客户端之间匹配架构很重要。将驱动程序软件与客户端 (ODBC/OLEDB) 相匹配也很重要。

关于database - 连接到 Sybase 数据库的 VBScript 错误 - 找不到提供程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29566585/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com