sql >> Base de Datos >  >> RDS >> Oracle

Error de sintaxis al intentar llamar a un paquete de Oracle usando ODBC en C#

Finalmente conseguí que funcionara. Agregué el tamaño de cada parámetro e hice correcciones a la llamada:la función tiene cuatro parámetros (1 de entrada, 3 de salida) y ningún valor de retorno:

using (OdbcCommand cmd = conn.CreateCommand())
{
    cmd.CommandText = "{ CALL TESTUSER.TESTPKG.TESTFUNC(?,?,?,?) }";
    cmd.CommandType = System.Data.CommandType.StoredProcedure;
    cmd.Parameters.Add("PARAM1", OdbcType.Decimal, 38).Direction = System.Data.ParameterDirection.Input;
    cmd.Parameters["PARAM1"].Value = var1;
    cmd.Parameters.Add("PARAM2", OdbcType.VarChar, 5).Direction = System.Data.ParameterDirection.Output;
    cmd.Parameters.Add("PARAM3", OdbcType.VarChar, 50).Direction = System.Data.ParameterDirection.Output;
    cmd.Parameters.Add("PARAM4", OdbcType.VarChar, 200).Direction = System.Data.ParameterDirection.Output;
    cmd.ExecuteNonQuery();

También encontré este documento muy útil:Using the Oracle ODBC Drivers with Third Productos para fiestas