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

VBScript error connecting to Sybase Database - Provider cannot be found

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

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

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

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

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

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

问题似乎与连接字符串的 Provider= 部分有关。这里值得注意的是,一旦我去掉 Provider= 部分,我就会得到这个错误:The specified DSN contains an architecture mismatch between the Driver and Application。所以这让我相信这里存在 32 位和 64 位不匹配。我对此进行了研究,结果发现解决该问题的方法是将 Provider= 添加到您的连接字符串中,以某种方式指定要使用的连接字符串。这是我在连接字符串中尝试过的提供程序列表:

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


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

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 位驱动程序,要么需要 运行 您的 vbscript 处于 32 位模式。

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

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

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

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