Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error en incremento columna con nulos update set
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error en incremento columna con nulos update set

Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error en incremento columna con nulos update set Responder citando

Estoy utilizando la siguiente consulta SQL para una aplicación de Facturación y Contabilidad (en Borland Delphi):

Código:

  with md.tcI do
  begin
    Close;
    SQL.Clear;
    SQL.Add('UPDATE ' + vtTablaIncidencia + ' SET ');
    SQL.Add('  incidenciaresolucion = :pincidenciaresolucion, ');
    SQL.Add('  estado = :pestado, ');
    SQL.Add('  completado = :pcompletado, ');
    SQL.Add('  aceptada = :paceptada, ');
    SQL.Add('  resueltatecnico = :presueltatecnico,');
    SQL.Add('  reaperturas = reaperturas + 1');   
    SQL.Add('  where codigo = :pCodigo');
    ParamByName('pincidenciaresolucion').DataType := ftString;
    ParamByName('pincidenciaresolucion').AsString := textoResolucion;
    ParamByName('pestado').DataType := ftString;
    ParamByName('pestado').AsString := 'Pendiente tarea técnica';
    ParamByName('pcompletado').DataType := ftInteger;
    ParamByName('pcompletado').AsInteger := 0;
    ParamByName('paceptada').DataType := ftString;
    ParamByName('paceptada').AsString := 'S';
    ParamByName('presueltatecnico').DataType := ftString;
    ParamByName('presueltatecnico').AsString := 'N';
    ParamByName('pCodigo').DataType := ftInteger;
    ParamByName('pCodigo').AsInteger := codigoIncidencia;
    try
      ExecSQL;
      Close;
    except
      close;
      raise;
    end;
  end;


El problema lo tengo en la línea "SQL.Add(' reaperturas = reaperturas + 1');", que funciona bien si "reaperturas" ya tiene algún valor, si no tiene valor (null) no funciona el incremento ¿cómo puedo solucionar esto sin modificar el código fuente?
MensajePublicado:
Mie Ago 26, 2009 6:04 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error en incremento columna con nulos update set Responder citando



Anuncios



varios escribió:
Estoy utilizando la siguiente consulta SQL para una aplicación de Facturación y Contabilidad (en Borland Delphi):

Código:

  with md.tcI do
  begin
    Close;
    SQL.Clear;
    SQL.Add('UPDATE ' + vtTablaIncidencia + ' SET ');
    SQL.Add('  incidenciaresolucion = :pincidenciaresolucion, ');
    SQL.Add('  estado = :pestado, ');
    SQL.Add('  completado = :pcompletado, ');
    SQL.Add('  aceptada = :paceptada, ');
    SQL.Add('  resueltatecnico = :presueltatecnico,');
    SQL.Add('  reaperturas = reaperturas + 1');   
    SQL.Add('  where codigo = :pCodigo');
    ParamByName('pincidenciaresolucion').DataType := ftString;
    ParamByName('pincidenciaresolucion').AsString := textoResolucion;
    ParamByName('pestado').DataType := ftString;
    ParamByName('pestado').AsString := 'Pendiente tarea técnica';
    ParamByName('pcompletado').DataType := ftInteger;
    ParamByName('pcompletado').AsInteger := 0;
    ParamByName('paceptada').DataType := ftString;
    ParamByName('paceptada').AsString := 'S';
    ParamByName('presueltatecnico').DataType := ftString;
    ParamByName('presueltatecnico').AsString := 'N';
    ParamByName('pCodigo').DataType := ftInteger;
    ParamByName('pCodigo').AsInteger := codigoIncidencia;
    try
      ExecSQL;
      Close;
    except
      close;
      raise;
    end;
  end;


El problema lo tengo en la línea "SQL.Add(' reaperturas = reaperturas + 1');", que funciona bien si "reaperturas" ya tiene algún valor, si no tiene valor (null) no funciona el incremento ¿cómo puedo solucionar esto sin modificar el código fuente?



Hay varias formas de solucionar el problema de los incrementos con valores nulos en MySQL, uno de ellos es utilizar la función COALESCE de MySQL, que te devolverá de varios valores el primero que no sea Null (nulo). Para tu caso sería algo así:

Código:

...
SQL.Add('  reaperturas = (COALESCE(reaperturas, 0) + 1)');
...


De esta forma, la función Coalesce comprobará si el valor de "reaperturas" es null, si lo es devolverá "0", si no lo es devolverá el valor actual de "reaperturas". Utilzando esta función sí te funcionará el incremento, incluso aunque el valor de "reaperturas" sea null (nulo).

Para más información sobre la función Coalesce:

http://www.ajpdsoft.com/modules.php?name=Encyclopedia&op=content&tid=802
MensajePublicado:
Mie Ago 26, 2009 6:14 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error en incremento columna con nulos update set Responder citando



Anuncios



También puedes solucionarlo utilizando estas otras funciones de MySQL:

CASE WHEN condición THEN result

Sería algo así:

Código:

SELECT
  CASE nombre_Campo
    WHEN IS NULL THEN 0
    ELSE nombre_Campo
  END
from nombre_tabla;


O también:

IF (condición, valor_si_true, valor_si_false)

Sería algo así:

Código:

SELECT IF(reaperturas is null, 0, reaperturas)
from incidencia;
MensajePublicado:
Mie Ago 26, 2009 7:22 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A