Как прочитать выходной массив оракула параметр c # - PullRequest
0 голосов
/ 19 декабря 2018

Привет, у меня есть эта процедура:

DECLARE 
 I_BIG_INSTITUTION_CODE VARCHAR2(10);
 I_BIG_ACTION_CODE VARCHAR2(10);
 O_CASES_TAB MY_API.VARCHAR_TAB;
 I_USER VARCHAR2(200);
 I_AD_USER VARCHAR2(200);
 I_LANGUAGE VARCHAR2(200);
 I_ASYS_ID NUMBER;
 O_RESULT_SUCCESSFUL BINARY_INTEGER;
 O_MESSAGE VARCHAR2(200);
BEGIN
 I_BIG_INSTITUTION_CODE := 'KRD';
 I_BIG_ACTION_CODE := 'ADD';
 I_USER := 'User User';
 I_AD_USER := 'u.user';
 I_LANGUAGE := 'PL';
 I_ASYS_ID := 100;
 MY_API.PACKAGE_NAME.GET_PACK_TO_SEND(
 I_BIG_INSTITUTION_CODE => I_BIG_INSTITUTION_CODE,
 I_BIG_ACTION_CODE => I_BIG_ACTION_CODE,
 O_CASES_TAB => O_CASES_TAB,
 I_USER => I_USER,
 I_AD_USER => I_AD_USER,
 I_LANGUAGE => I_LANGUAGE,
 I_ASYS_ID => I_ASYS_ID,
 O_RESULT_SUCCESSFUL => O_RESULT_SUCCESSFUL,
 O_MESSAGE => O_MESSAGE);
  if O_CASES_TAB.count>0 then
   for i in  O_CASES_TAB.first..O_CASES_TAB.last loop
    DBMS_OUTPUT.PUT_LINE('O_CASES_TAB = ' || O_CASES_TAB(i));
   end loop;
  end if;
 DBMS_OUTPUT.PUT_LINE('O_RESULT_SUCCESSFUL = ' || O_RESULT_SUCCESSFUL);
 DBMS_OUTPUT.PUT_LINE('O_MESSAGE = ' || O_MESSAGE);
END;

Процедура возвращает что-то вроде этого: Результат процедуры

Теперь мне нужно прочитать o_cases_tab параметр в C #, но я не знаю, как это сделать.Вот код, который пытается это сделать:

public void GetPackToSend()
    {
        using (var connection = ConnectionFactory.GetConnection())
        {
            connection.Open();
            using (var command = connection.CreateCommand())
            {
                command.CommandText = "MY_API.PACKAGE_NAME.GET_PACK_TO_SEND";
                command.CommandType = CommandType.StoredProcedure;
                command.Parameters.Add("input_parameter1", OracleDbType.NVarchar2).Value = "value_1" ;
                command.Parameters.Add("input_parameter2", OracleDbType.NVarchar2).Value = "value_2";
                AddOutArrayParameter(command, "o_cases_tab", "MY_API.VARCHAR_TAB", 10);
                command.Parameters.AddRange(OracleParameterHelper.GetDefaultInputParameters()
                    .ToArray());
                command.Parameters.AddRange(OracleParameterHelper.GetDefaultOutputParameters().ToArray());

                try
                {
                    command.ExecuteNonQuery();

                    var dbResult = new Tuple<string, string, object>(
                        command.Parameters["o_result_successful"].Value.ToString(),
                        command.Parameters["o_message"].Value.ToString(),
                        command.Parameters["o_cases_tab"].Value);
                }
                catch (OracleException ex)
                {
                    throw ex;

                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
        }

dbResult = {(1, null, System.Object [])} То есть в параметре o_cases_tab У меня есть: System.Object []

Метод addOutArrayParameter

private static void AddOutArrayParameter(OracleCommand command, string paramName,
        string paramTypeName, int size = 1)
    {
        var parameter = command.CreateParameter();
        parameter.Size = size;
        parameter.ArrayBindSize = size;
        parameter.UdtTypeName = paramTypeName;
        parameter.ParameterName = paramName;
        parameter.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
        parameter.Direction = ParameterDirection.Output;
        parameter.OracleDbType = OracleDbType.Array;
        command.Parameters.Add(parameter);
    }

Я определенно делаю глупую ошибку, но впервые работаюс оракулом, поэтому я прошу снисхождения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...