调用Oracle存储过程时,ORA-06550参数的数量或类型错误

时间:2012-11-06 14:22:27

标签: c# .net database oracle stored-procedures

procedure select_card_transaction(trans_id   nvarchar2,
                                    usr_id    number,
                                    Quantity out number) is
  begin
    select count(*)
      into Quantity
      from user_cards u
     where u.transaction_id = trans_id
       and u.user_id = usr_id;
  end;

并使用它:

using(var conn = new OracleConnection(Settings.Default.OraWUConnString))
            { 
                var cmd = conn.CreateCommand();
                cmd.CommandText = "for_temporary_testing.select_card_transaction";
                cmd.CommandType = CommandType.StoredProcedure;



                cmd.Parameters.AddWithValue("trans_id", TransactionID);
                cmd.Parameters.AddWithValue("usr_id", UserID);

                var q = new OracleParameter("Quantity", OracleType.Number);
                q.Direction = ParameterDirection.Output;
                cmd.Parameters.Add(q);
                //cmd.Parameters[0].OracleType = OracleType.NVarChar;
                //cmd.Parameters[1].OracleType = OracleType.Number; 

                conn.Open();
                var obj = cmd.ExecuteNonQuery();

                conn.Close();
                return (int)q.Value == 1;
            }

它返回以下错误。 ORA-06550在调用Oracle存储过程时错误的参数数量或类型... 任何想法?

2 个答案:

答案 0 :(得分:2)

我之前遇到过同样的问题。您使用的是ODP.Net驱动程序吗?我能够通过首先添加输出参数来解决问题。这需要在输入参数之前完成。在你的情况下,它看起来像

 using(var conn = new OracleConnection(Settings.Default.OraWUConnString))
            { 
                conn.Open();

                var cmd = conn.CreateCommand();
                cmd.CommandText = "for_temporary_testing.select_card_transaction";
                cmd.CommandType = CommandType.StoredProcedure;

                // Return value parameter has to be added first !
                var Quantity = new OracleParameter();
                Quantity.Direction = ParameterDirection.ReturnValue;
                Quantity.OracleDbType = OracleDbType.Int32;
                cmd.Parameters.Add(Quantity);

                //now add input parameters
                var TransID = cmd.Parameters.Add("trans_id", TransactionID);
                TransID.Direction = ParameterDirection.Input;
                TransID.OracleDbType = OracleDbType.NVarchar2;

                var UsrID = cmd.Parameters.Add("usr_id", UserID);
                UsrID.Direction = ParameterDirection.Input;
                UsrID.OracleDbType = OracleDbType.Int32;

                cmd.ExecuteNonQuery();

                conn.Close();
                return Convert.ToInt32(Quantity.Value);
            }

答案 1 :(得分:2)

问题出在参数中。它是null并且oracle返回错误。我知道如果参数是 null ,它应该以 DBNULL

的形式发送