用于Oracle语法错误或访问冲突的Microsoft ODBC驱动程序(-2147217900)

问题描述 投票:0回答:1

我有一个连接到Oracle数据库的大型VB程序。

strCn = "Driver={Microsoft ODBC for Oracle};" & _
        "SERVER=PSPROD;"

Set Cn = New ADODB.Connection
Cn.ConnectionString = strCn
Cn.CursorLocation = adUseNone
Cn.Open

我的程序有很多用户,所以我有一个表,其中包含每个用户的登录名及其对各种表的访问权限。我在程序启动时创建所有用户的记录集,然后从找到USERNAME和PASSWORD的记录集中选择USERNAME和GRANTED_ROLE。我使用“设置角色'GRANTED_ROLE'标识'password'”statment和Cn.Execute语句来设置用户的访问权限。这一切都在模块中完成。

在表单上,​​我想调用一个存储过程,它将SELECT,INSERT和UPDATE信息放入另一个模式的表中。当我使用以下代码创建与数据库的新连接时,我能够调用并运行存储过程:

Dim cmd5040 As ADODB.Command Dim conn5040 As ADODB.Connection Dim param5040 As ADODB.Parameter

设置conn5040 =新ADODB.Connection conn5040 =“Driver = {Microsoft ODBC for Oracle};” &_“SERVER = PSPROD; UID = XXXXXXX; PWD = XXXXXXXX”conn5040。打开

设置cmd5040 =新ADODB.Command

使用cmd5040 .ActiveConnection = conn5040 .CommandType = adCmdStoredProc .CommandText =“S4115040_IMPORT_NEWBIDITEMSPES.S4115040_CheckTime”

.Parameters.Append .CreateParameter(, adInteger, adParamInputOutput, 5)
.Parameters.Append .CreateParameter(, adVarChar, adParamInputOutput, 400)

结束

cmd5040(0)= 0 cmd5040(1)=“”cmd5040.CommandTimeout = 300

cmd5040.Execute conn5040.Close

但是,当我尝试在程序首次启动时使用相同的连接('Cn')时,我收到错误消息“-2147217900 [Microsoft] [Oracle的ODCB驱动程序]语法错误或访问冲突”。我的代码是:

Dim cmd5040 As ADODB.Command Dim param5040 As ADODB.Parameter

设置cmd5040 =新ADODB.Command

使用cmd5040 .ActiveConnection = Cn .CommandType = adCmdStoredProc .CommandText =“S4115040_IMPORT_NEWBIDITEMSPES.S4115040_CheckTime”

.Parameters.Append .CreateParameter(, adInteger, adParamInputOutput, 5)
.Parameters.Append .CreateParameter(, adVarChar, adParamInputOutput, 400)

结束

cmd5040(0)= 0 cmd5040(1)=“”

cmd5040.Execute

我和我的DBA一起工作过。她给了我直接授权和直接执行权限,我仍然收到错误消息。

我究竟做错了什么?我是否应该能够使用原始连接来运行存储过程?或者我必须创建第二个连接?

odbc syntax-error drivers
1个回答
0
投票

编辑:在审查您的代码时,我注意到原始连接Cn指定了驱动程序和服务器名称,而第二个连接conn5040指定了驱动程序,服务器名称,用户和密码。

因此,您调用的存储过程可能需要原始cn连接未指定的用户和密码


原始答案:

当您尝试使用它时,请确保变量cn仍在范围内。如果它在模块中声明,那么它应该在任何SubFunction之外声明,如果其他模块应该能够访问它,它应该被声明为Public

Option Explicit

Public cn as ADODB.Connection

Sub foo()
...

假设cn仍然在范围内,你可以检查State引用的对象的cn属性,看看Connection是否仍然是开放的。

If (cn.State = adStateClosed) Then
    ' we have a problem
    ...
© www.soinside.com 2019 - 2024. All rights reserved.