连接到 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
但它导致了错误:找不到提供者。可能没有正确安装。
以下是您可能需要确定问题原因的一些系统信息:
- 脚本将在 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=
部分,我就会得到这个错误:The specified DSN contains an architecture mismatch between the Driver and Application。所以这让我相信这里存在 32 位和 64 位不匹配。我对此进行了研究,结果发现解决该问题的方法是将 Provider=
添加到您的连接字符串中,以某种方式指定要使用的连接字符串。这是我在连接字符串中尝试过的提供程序列表:
- Sybase ASE OLE DB 提供程序
- Sybase.ASEOLEDBProvider
- ASEOLEDB
- ASEOLEDB.1
- Sybase.ASEOLEDBProvider.2
- Sybase
- 优势 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 位驱动程序,要么需要 运行 您的 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)。
我正在编写连接到 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
但它导致了错误:找不到提供者。可能没有正确安装。
以下是您可能需要确定问题原因的一些系统信息:
- 脚本将在 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=
部分,我就会得到这个错误:The specified DSN contains an architecture mismatch between the Driver and Application。所以这让我相信这里存在 32 位和 64 位不匹配。我对此进行了研究,结果发现解决该问题的方法是将 Provider=
添加到您的连接字符串中,以某种方式指定要使用的连接字符串。这是我在连接字符串中尝试过的提供程序列表:
- Sybase ASE OLE DB 提供程序
- Sybase.ASEOLEDBProvider
- ASEOLEDB
- ASEOLEDB.1
- Sybase.ASEOLEDBProvider.2
- Sybase
- 优势 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 位驱动程序,要么需要 运行 您的 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)。