我有一个连接到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一起工作过。她给了我直接授权和直接执行权限,我仍然收到错误消息。
我究竟做错了什么?我是否应该能够使用原始连接来运行存储过程?或者我必须创建第二个连接?
编辑:在审查您的代码时,我注意到原始连接Cn
指定了驱动程序和服务器名称,而第二个连接conn5040
指定了驱动程序,服务器名称,用户和密码。
因此,您调用的存储过程可能需要原始cn
连接未指定的用户和密码
原始答案:
当您尝试使用它时,请确保变量cn
仍在范围内。如果它在模块中声明,那么它应该在任何Sub
或Function
之外声明,如果其他模块应该能够访问它,它应该被声明为Public
Option Explicit
Public cn as ADODB.Connection
Sub foo()
...
假设cn
仍然在范围内,你可以检查State引用的对象的cn
属性,看看Connection
是否仍然是开放的。
If (cn.State = adStateClosed) Then
' we have a problem
...