Ver Mensaje Individual
  #1 (permalink)  
Antiguo 25/11/2010, 12:07
Ylatoma
 
Fecha de Ingreso: agosto-2007
Mensajes: 12
Antigüedad: 17 años, 2 meses
Puntos: 0
Información Error al Actualizar registros en portgresql con c#

Hola a todos espero me puedan ayudar, estoy una actualización de registros desde C# asciendo unos de una función , pero al momento de actualizar no realiza la actualización desde c# , pero en el transac del postgresql si lo hace la actualización del registro. acá les dejo el código que echo, de antemano agradezco a sus respuestas
Código SQL:
Ver original
  1. CREATE TABLE ALMACEN.TIPO_ALMACEN
  2. (
  3.     IDTIPO_ALMACEN       CHAR(4)  NOT NULL ,
  4.     DESCRIPCION          VARCHAR(30)  NULL ,
  5.     ABREV                VARCHAR(10)  NULL ,
  6.     ESTADO               CHAR(1)  NULL
  7.  
  8. )
  9.  
  10.  
  11.  
  12. CREATE OR REPLACE FUNCTION Update_Tipo_almacen(item_id CHAR(4),descrip VARCHAR(30),desc_abrev CHAR(10),std CHAR(1))
  13. RETURNS void AS
  14. $BODY$
  15. DECLARE
  16. --   loc_result    CHAR(50);
  17. BEGIN
  18. UPDATE ALMACEN.TIPO_ALMACEN
  19.  SET
  20.     DESCRIPCION    = descrip,
  21.     ABREV    = desc_abrev,
  22.     ESTADO     = std
  23. WHERE IDTIPO_ALMACEN = item_id;
  24. END;
  25. $BODY$
  26. LANGUAGE 'plpgsql' VOLATILE;



Código VB:
Ver original
  1. NpgsqlCommand Exec;
  2.  
  3.  public    int  ActualizarRegistro(LayerIdentidad.Almacen.Almacen.IdTipAlmacen IdCls)
  4.         {
  5.  
  6.  
  7.             SIGConnection.OpenConnection();
  8.             Exec = new NpgsqlCommand("Update_Tipo_almacen", SIGConnection.Connection);
  9.             Exec.CommandType = CommandType.StoredProcedure;
  10.             Exec.Parameters.Add(":item_id", NpgsqlTypes.NpgsqlDbType.Char, 4).Value = IdCls.IdReg;
  11.             Exec.Parameters.Add(":descrip", NpgsqlTypes.NpgsqlDbType.Varchar, 30).Value = IdCls.Descripcion;
  12.             Exec.Parameters.Add(":desc_abrev", NpgsqlTypes.NpgsqlDbType.Varchar, 10).Value = IdCls.Desc_avreiada;
  13.             Exec.Parameters.Add(":std", NpgsqlTypes.NpgsqlDbType.Char, 1).Value = IdCls.Estado;
  14.           //  Exec.Parameters.Add(":existe:", NpgsqlTypes.NpgsqlDbType.Boolean).Direction = ParameterDirection.Output;
  15.             try
  16.             {
  17.                 Res = Exec.ExecuteNonQuery();
  18.            
  19.             }
  20.             catch (Exception) { }
  21.             finally
  22.             {
  23.                 Exec.Dispose();
  24.                 SIGConnection.CloseConnection();
  25.             }
  26.             return Res;
  27.  
  28.  
  29.  
  30.  public int  ActualizarRegistro(LayerIdentidad.Almacen.Almacen.IdTipAlmacen IdCls)
  31.         {
  32.             return data.ActualizarRegistro(IdCls);
  33.         }
  34.  
  35.  
  36.  LayerLogic.Almacen.Almacen.LogTipAlmacen Log1 = new LayerLogic.Almacen.Almacen.LogTipAlmacen();
  37.                             LayerIdentidad.Almacen.Almacen.IdTipAlmacen Id1 = new LayerIdentidad.Almacen.Almacen.IdTipAlmacen();
  38.                             Id1.IdReg = TxtId.Text;
  39.                             Id1.Descripcion = TxtDesc.Text;
  40.                             Id1.Desc_avreiada = TxtDesAbr.Text;
  41.                             Id1.Estado = "0";
  42.                             MessageBox.Show(Log1.ActualizarRegistro(Id1).ToString ());
  43.                             if (Log1.ActualizarRegistro(Id1) ==   1)
  44.                             {
  45.                                 Utilidades.MensajeOk("Registrado Actualizado  Correctamente");
  46.                             }
  47.                             else
  48.                             {
  49.                                 Utilidades.MensajeAlerta("Error. En la Actualización de Datos.");
  50.                             }
  51.  
  52.        
  53.  
  54.            
  55.         }