我正在尝试使用 C# 中的 Dd2OleDb ver.6 驱动程序调用 DB2 中的存储过程。调用 时,会抛出 SQLCode 为 -379 的cmd.ExecuteNonQuery
an 。OleDbException
完整消息如下。
我对另一个运行良好的存储过程有类似的调用。
在使用 IBM DB2 客户端时,这两个存储过程都可以正常工作,但是我们正在尝试采用使用 OleDB 的标准。所有参数值的类型都正确且在范围内。
操作系统:Windows 8.1
.Net 框架 4.6.1 Visual Studio 2017
C# 客户端
const string storedProc = @"T99XXX.CI419UPDATE";
using (var conn = GetCisDBConnection())
using (var cmCommand = new OleDbCommand(storedProc, conn))
{
cmCommand.CommandType = System.Data.CommandType.StoredProcedure;
var pCustNbr = new OleDbParameter("P_CUST_NBR", customerNbr);
var pPremNbr = new OleDbParameter("P_PREM_NBR", premiseNbr);
var pCmsgType = new OleDbParameter("P_CMSG_TYPE", cmsgType);
var pCmsgText = new OleDbParameter("P_CMSG_TEXT", cmsgText);
var pStatus = new OleDbParameter("O_STATUS", OleDbType.Integer, 10, System.Data.ParameterDirection.Output, true, 0, 0, null, System.Data.DataRowVersion.Current, null);
var pSqlCode = new OleDbParameter("O_SQLCODE", OleDbType.Integer, 10, System.Data.ParameterDirection.Output, true, 0, 0, null, System.Data.DataRowVersion.Current, null);
cmCommand.Parameters.Add(pCustNbr);
cmCommand.Parameters.Add(pPremNbr);
cmCommand.Parameters.Add(pCmsgType);
cmCommand.Parameters.Add(pCmsgText);
cmCommand.Parameters.Add(pStatus);
cmCommand.Parameters.Add(pSqlCode);
conn.Open();
cmCommand.ExecuteNonQuery(); // Returns -379
存储过程头:
CREATE PROCEDURE T14TOPS.CI419UPDATE (
IN P_CUST_NBR DECIMAL(7,0),
IN P_PREM_NBR DECIMAL(7,0),
IN P_CMSG_TYPE DECIMAL(3,0),
IN P_CMSG_TEXT VARCHAR(980),
OUT O_STATUS INTEGER,
OUT O_SQLCODE INTEGER)
完整的错误信息是
System.Data.OleDb.OleDbException
HResult=0x80040E14
消息=发生内部网络库错误。发生网络级语法错误。SQLSTATE:HY000,SQLCODE:-379
源=System.Data堆栈跟踪:
在 System.Data.OleDb.OleDbCommand.ExecuteCommandTextErrorHandling(OleDbHResult hr) 在 System.Data.OleDb.OleDbCommand.ExecuteCommandTextForMultpleResults(tagDBPARAMS dbParams, Object& executeResult) 在 System.Data.OleDb.OleDbCommand.ExecuteCommandText(Object& executeResult) 在 System.Data。在 System.Data.OleDb.OleDbCommand.ExecuteReaderInternal(CommandBehavior 行为,字符串方法)在 System.Data.OleDb.OleDbCommand.ExecuteNonQuery() 在 CustomerCare.DataAccess.CisDataAccess.UpdateLog( C:\TFS\MSServer\Source\Main\DataAccess\CisDataAccess.cs 中的小数 customerNbr、小数 前提Nbr、小数 cmsgType、String cmsgText):C 中 DataAccessTest.CisDataAccessTest.UpdateLog_Test() 的第 103 行:\TFS\MSServer\Source\Main\DataAccessTest\CisDataAccessTest.cs:第 30 行
System.IndexOutOfRangeException
HResult=0x80131508
消息=此 OleDbParameterCollection 的索引 -1 无效,计数为 6。
源=系统.数据