Oracle11g 将datatable传递给Oracle存储过程的refcursor

Oracle11g 将datatable传递给Oracle存储过程的refcursor,oracle11g,odp.net,Oracle11g,Odp.net,我正在使用ODP.NET和Oracle 11g客户端。我将一个数据表传递给一个以refcursor作为输入的过程 dtSample是DataTable,有四列,分别称为Type、Name、Size和Description 我出错了 无效的参数绑定,参数名称:ParameterName 排队 db.ExecuteNonQuery(oracleCommand); 完整代码: OracleCommand oracleCommand = new OracleCommand(); oracleComma

我正在使用ODP.NET和Oracle 11g客户端。我将一个数据表传递给一个以
refcursor
作为输入的过程

dtSample
DataTable
,有四列,分别称为
Type
Name
Size
Description

我出错了

无效的参数绑定,参数名称:ParameterName

排队

db.ExecuteNonQuery(oracleCommand);
完整代码:

OracleCommand oracleCommand = new OracleCommand();
oracleCommand.CommandType = CommandType.StoredProcedure;
oracleCommand.CommandText = "PCK_ADMIN.PROC_INS";
oracleCommand.Parameters.Add("P_USERID", OracleDbType.Varchar2).Value = "abcd";
oracleCommand.Parameters.Add("P_ATTACH_LIST", OracleDbType.RefCursor).Value = dtSample;
oracleCommand.Parameters.Add("P_out", OracleDbType.Int32).Direction = ParameterDirection.Output;
oracleCommand.Parameters.Add("P_msg", OracleDbType.Varchar2, 50).Direction = ParameterDirection.Output;

db.ExecuteNonQuery(oracleCommand);
存储过程:

PROCEDURE PROC_INS(  P_USERID IN VARCHAR2,
                            P_ATTACH_LIST IN SYS_REFCURSOR,
                            P_out      OUT NUMBER,
                             P_msg     OUT VARCHAR2) AS

V_BRS_USERID         VARCHAR2(50);
V_ATTACHMENT_TYPE_ID BRS_USER_ATTACHMENT.ATTACHMENT_TYPE_ID%TYPE;
V_FILE_NAME          BRS_USER_ATTACHMENT.FILE_NAME%TYPE;
V_FILE_SIZE          BRS_USER_ATTACHMENT.FILE_SIZE%TYPE;
V_FILE_DESCR         BRS_USER_ATTACHMENT.FILE_DESCR%TYPE; 

BEGIN 
LOOP 
FETCH P_ATTACH_LIST INTO V_BRS_USERID, V_ATTACHMENT_TYPE_ID,V_FILE_NAME, V_FILE_SIZE, V_FILE_DESCR; 
EXIT WHEN P_ATTACH_LIST%NOTFOUND; 
    INSERT INTO USER_ATTACHMENT VALUES
            (SEQ_RER_EMP_REP_ID.NEXTVAL,
              V_BRS_USERID,
              V_ATTACHMENT_TYPE_ID,
              V_FILE_NAME,
              V_FILE_SIZE,
              V_FILE_DESCR,
              NULL,
              NULL,
              0,
              0,
              'A',
              P_USERID,
              SYSDATE,
              NULL,
              NULL
            );

END LOOP; 

CLOSE P_ATTACH_LIST;
EXCEPTION
  WHEN OTHERS THEN
  ROLLBACK; -- Transaction mgmt
  p_out := 2;
  p_msg := sqlerrm;

END PROC_REG_INS_ATTACH;            

你不能。您需要传入另一个ref游标,并且只能将其作为存储过程/函数的输出,或者作为对匿名块中的表的查询。。。也许您可以创建一个使用不同数据类型(如关联数组)的包装器存储过程

我认为你做不到。那么,我怎样才能将数据从C#传递到RefCursor呢?你做不到。您需要传入另一个ref游标,并且只能将其作为存储过程/函数的输出,或者作为对匿名块中的表的查询。。。也许您可以创建一个使用不同数据类型(如关联数组)的包装器存储过程。