Использование выходного параметра типа SYS_refcursor - PullRequest
1 голос
/ 12 октября 2011

В моей базе данных есть хранимая процедура с параметром OUTPUT типа SYS_REFCURSOR. Сторона приложения написана на C #. Могу ли я присвоить выходной параметр этой процедуры Datatable, например:

 .............
 OracleConnection con=new OracleConnection(......);
 OracleCommand cmd=new OracleCommand("MyStoredProc",con);
 cmd.CommandType=CommandType.StoredProcedure;
 cmd.Parameters.Add("REC_CUR",OracleType.Cursor).Direction=ParameterDirection.Output;
 con.Open();
 cmd.ExecuteNonQuery();
 DataTable dt=(DataTable)cmd.Parameters["REC_CUR"].value;//is this legal?

Ответы [ 2 ]

2 голосов
/ 14 октября 2011

Вот ответ на мой вопрос.Если выходной параметр хранимой процедуры имеет тип SYS_REFCURSOR, то команда

cmd.Parameters["REC_CUR"].value

вернет объект OracleDataReader, а не таблицу.И нет ни явного, ни явного приведения из OracledataReader в DataTable.

1 голос
/ 04 марта 2014

Вы можете использовать OracleDataAdapter, как показано ниже,

пример кода с несколькими параметрами out с RefCursor:

using (OracleCommand cmd = new OracleCommand("SP1", OraCon) { CommandType = System.Data.CommandType.StoredProcedure })
{
    var parm_nic = cmd.Parameters.Add("parm_nic", OracleDbType.NVarchar2);
    parm_nic.Value = msgBody;

    var pram_Name = cmd.Parameters.Add("pram_Name", OracleDbType.NVarchar2, 150, ParameterDirection.Output);
    var pram_PAdress = cmd.Parameters.Add("pram_PAdress", OracleDbType.NVarchar2, 150, ParameterDirection.Output);
    var output = cmd.Parameters.Add("pram_status", OracleDbType.RefCursor, ParameterDirection.Output);
    OraCon.Open();

    OracleDataAdapter ad = new OracleDataAdapter(cmd);
    OracleCommandBuilder cb = new OracleCommandBuilder(ad);

    DataTable dt = new DataTable();
    ad.Fill(dt);

    var address = pram_PAdress.Value;
    var name = pram_Name.Value;
}
...