Ver Mensaje Individual
  #1  
Antiguo 24-10-2003
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Reputación: 26
guillotmarc Va por buen camino
Hola.

Cita:
Posteado originalmente por cadetill
El tema de que te devuelva null la suma, acabo de probar en Firebird 1.5 y, aunque un valor de los que entran en la suma sea Null, la suma en sí la hace correctamente devolciendo la suma de los demás registros
Me extraña que la suma te devuelva un valor, en caso de que un registro sea nulo, no deberia hacerlo. Puesto que el estándar SQL indica que un valor operado con nulo, es nulo. Por eso cuando alguno de los valores que interviene en la suma es nulo, el resultado es nulo.

Para solucionarlo, debes utilizar alguna función que te sustituya el nulo por un 0. Por ejemplo, la función COALESCE :

select NUMALU, SUM(0 - COALESCE(econo.impdebe, 0) + COALESCE(econo.imphaber,0)) as IMPORTE
from econo
where NUMALU = :Parametro
GROUP BY NUMALU
ORDER BY NUMALU

El problema es que esto te funcionará en Firebird 1.5, pero creo que Interbase 7 no soporta esta función. En ese caso la tendrás que sustituir por una UDF.

La semana pasada hablamos precisamente de este mismo problema en otro hilo, si lo buscas encontrarás información sobre como utilizar una UDF.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita