![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
La función que estás buscando se llama COALESCE y la documentación de la misma está en el archivo "Firebird_v15.108_ReleaseNotesSpanish.pdf" que lo podés bjar de la página "http://www.ibphenix.com".
Esta función te permite obtener valores no nulos: el uso sería más o menos el siguiente: --> COALESCE(CampoDeLaTabla, 0) para que te devuelva un cero en caso de que el Campo sea NULL. |
|
#2
|
||||
|
||||
|
Cita:
// Saludos |
|
#3
|
|||
|
|||
|
trabajar tablas que permitan campos nulos es muy util, pero es necesaria mucha dedicación del programador para no tener problemas ya que cualquier operación que los implique dara por resultado un nulo
existen funciones para cada motor de base de datos que permiten manejar los nulos con seguridad como los ya nombrados (por ejemplo: isnull, coalecse y case en sql serber) y aun sin estas funciones se puede vivir con ellos pero creanme cuando no sean necesarios los nulos no los usen, declaren que los campos númericos no puedan ser nulos y con valor por default 0 y se quitan un monton de dolores de cabeza yo soy un gran partidario de usar nulos, pero solo cuando es util su uso y nunca configuro las bases de datos para que no use los nulos saludos ![]() |
|
#4
|
||||
|
||||
|
DEPROE
Yo concuerdo contigo en evitar el uso de valores null. Pero como ya te mencioné en mi respuesta a tu mensaje anterior, éste no es el problema aquí. Si te fijas en la tabla ejemplo que puse, no hay ningún valor null e incluso los campos podrían tener la restrición de no aceptar nulos. Los valores null surgen como consecuencia de la consulta en particular ya que puede haber cuentas sin un tipo de movimiento en particular. vpepen Además de todo lo dicho y los intentos realizados, lo cierto es que a veces conviene modificar un poco la estructura de nuestras tablas para adecuarse mejor al tipo de consultas que se hagan. En tu caso el campo Tipo_Mov indica si el monto es un débito o un crédito, que básicamente se traduce en anteponer o no un signo negativo al monto. Así como usas 'C' o 'D' bien podrías usar 'CREDITO' o 'DEBITO' o cualquier par de valores que disciernan entre un concepto y otro sin afectar la lógica del sistema. Una vez asumido lo anterior podrías optar simplemente por los valores Código:
1 - crédito -1 - débito Con este simple cambio te evitas todos estos dolores de cabeza con esta consulta que te sirve incluso en Paradox:
o bien, si quieres los nombres:
Lo único que estamos haciendo aquí es multiplicar monto por un factor adecuado. En el caso de crédito (1 + tipo_mov)/2 valúa a 1 si es un crédito o 0 si es un débito, de manera que sum() sólo suma los créditos. Análogamente, (1 - tipo_mov)/2 valúa a 0 si es un crédito o 1 si es un débito de manera que sum() sólo suma los débitos, y en el caso del balance, tipo_mov simplemente multiplica por -1 los débitos. Así como usas 1 y -1 podrías usar cualquier par de valores numéricos. Los factores serían un poco más complejos pero aún así evitas tanta vuelta y dolor de cabeza. // Saludos Última edición por roman fecha: 17-11-2004 a las 16:57:29. |
|
#5
|
||||
|
||||
|
Roman,
Pondré en práctica las alternativas posteadas por ti y ya te informaré más adelante cómo me va. Te agradezco tu tiempo y el de los demás compañeros, asi como principalmente el conocimiento compartido. Víctor.- |
|
#6
|
||||
|
||||
|
Hola Foro
Quería saber si alguien había descubierto cemo resolver el null en "InterBase".
el problema es que hago Select A, B ,C ,A+B+C as Total From prueba y si alguno de los campos es null total es null. Muchas gracias. |
|
#7
|
||||
|
||||
|
Cita:
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
|