2
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 ストアド プロシージャを呼び出すときの引数の数またはタイプが正しくありません... 何かアイデアはありますか?

4

2 に答える 2

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);
            }
于 2012-11-06T14:44:53.350 に答える
2

パラメータに問題がありました。null であり、oracle はエラーを返しました。引数がnullの場合、 DBNULLとして送信する必要があることがわかりました

于 2012-11-06T15:04:58.453 に答える