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 al restar dos columnas cuando una de ellas es null
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error al restar dos columnas cuando una de ellas es null

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 al restar dos columnas cuando una de ellas es null Responder citando

Estoy desarrollando una aplicación de facturación, con SQL realizo una resta de dos campos (columnas), me funciona bien siempre y cuando tengan valor las dos, pero si una de ellas tiene valor nulo (null) no hace la resta correctamente.

Este el el código que utilizo:

Código:

procedure TformFactura.llenarGrid(Posicion: Integer);
begin
  md.tcfactura.Close;
  md.tcfactura.SQL.Clear;
  md.tcfactura.SQL.Add('select f.*, c.nombre Cliente');
  md.tcfactura.SQL.Add('  f.importetotal - f.importecobrado, ');
  md.tcfactura.SQL.Add('from factura f, cliente c');
  md.tcfactura.SQL.Add('where f.codigocliente = c.codigo');
  md.tcfactura.Open;
  md.tcFactura.RecNo := Posicion;
end;



Utilizo Delphi como lenguaje de programación.

¿Hay alguna función en MySQL para que convierta el null a cero o algo para solucionar este problema?

Como he dicho utilizo Borland Delphi 6 y MySQL Server 5.0.
MensajePublicado:
Mar Abr 13, 2010 8:19 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error al restar dos columnas cuando una de ellas es null Responder citando



Anuncios



varios escribió:
Estoy desarrollando una aplicación de facturación, con SQL realizo una resta de dos campos (columnas), me funciona bien siempre y cuando tengan valor las dos, pero si una de ellas tiene valor nulo (null) no hace la resta correctamente.

Este el el código que utilizo:

Código:

procedure TformFactura.llenarGrid(Posicion: Integer);
begin
  md.tcfactura.Close;
  md.tcfactura.SQL.Clear;
  md.tcfactura.SQL.Add('select f.*, c.nombre Cliente');
  md.tcfactura.SQL.Add('  f.importetotal - f.importecobrado, ');
  md.tcfactura.SQL.Add('from factura f, cliente c');
  md.tcfactura.SQL.Add('where f.codigocliente = c.codigo');
  md.tcfactura.Open;
  md.tcFactura.RecNo := Posicion;
end;



Utilizo Delphi como lenguaje de programación.

¿Hay alguna función en MySQL para que convierta el null a cero o algo para solucionar este problema?

Como he dicho utilizo Borland Delphi 6 y MySQL Server 5.0.


Puedes utilizar la función MySQL "COALESCE", de esta forma:

Código:

procedure TformFactura.llenarGrid(Posicion: Integer);
begin
  md.tcfactura.Close;
  md.tcfactura.SQL.Clear;
  md.tcfactura.SQL.Add('select f.*, c.nombre Cliente');
  md.tcfactura.SQL.Add('COALESCE(f.importetotal, 0) - ');
  md.tcfactura.SQL.Add('COALESCE(f.importecobrado, 0) ImportePendiente');
  md.tcfactura.SQL.Add('from factura f, cliente c');
  md.tcfactura.SQL.Add('where f.codigocliente = c.codigo');
  md.tcfactura.Open;
  md.tcFactura.RecNo := Posicion;
end;
MensajePublicado:
Mar Abr 13, 2010 8:22 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error al restar dos columnas cuando una de ellas es null Responder citando



Anuncios



La función COALESCE devolverá de varios valores (pasados como parámetro) el primero que no sea Null (nulo).

Si quieres ver más información sobre la función Coalesce de MySQL:

http://www.ajpdsoft.com/modules.php?name=Encyclopedia&op=content&tid=802
MensajePublicado:
Mar Abr 13, 2010 8:26 pm
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