Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-11-2004
frudolph frudolph is offline
Miembro
 
Registrado: oct 2004
Posts: 40
Poder: 0
frudolph Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 17-11-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por frudolph
está en el archivo "Firebird_v15.108_ReleaseNotesSpanish.pdf"
El problema es que vpepen está usando Interbase y no Firebird. Y de hecho el mismo procedimiento almacenado que puse no estoy seguro de que funcione en Interbase. Quizá una UDF sería lo más conveniente.

// Saludos
Responder Con Cita
  #3  
Antiguo 17-11-2004
DEPROE DEPROE is offline
Miembro
 
Registrado: nov 2004
Posts: 10
Poder: 0
DEPROE Va por buen camino
Cool Que pasa con los campos nulos

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
Responder Con Cita
  #4  
Antiguo 17-11-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
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
cambiando el tipo de datos de Tipo_Mov a un tipo numérico.

Con este simple cambio te evitas todos estos dolores de cabeza con esta consulta que te sirve incluso en Paradox:

Código SQL [-]
select
  cod_cta,
  sum((1 + tipo_mov)*monto/2) as credito,
  sum((1 - tipo_mov)*monto/2) as debito,
  sum(tipo_mov*monto) as balance
from
  movimientos
group by
  cod_cta

o bien, si quieres los nombres:

Código SQL [-]
select
  nombre,
  sum((1 + tipo_mov)*monto/2) as credito,
  sum((1 - tipo_mov)*monto/2) as debito,
  sum(tipo_mov*monto) as balance
from
  movimientos
left join
  cuentas on cuentas.codigo = movimientos.cod_cta
group by
  nombre

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.
Responder Con Cita
  #5  
Antiguo 17-11-2004
Avatar de vpepen
vpepen vpepen is offline
Miembro
 
Registrado: nov 2003
Ubicación: Higüey
Posts: 104
Poder: 23
vpepen Va por buen camino
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.-
Responder Con Cita
  #6  
Antiguo 26-07-2006
Avatar de Carmelo Cash
Carmelo Cash Carmelo Cash is offline
Miembro
 
Registrado: jul 2003
Ubicación: Buenos Aires
Posts: 265
Poder: 23
Carmelo Cash Va por buen camino
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.
Responder Con Cita
  #7  
Antiguo 27-07-2006
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is online now
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 19.437
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por Carmelo Cash
... y si alguno de los campos es null total es null.
Normalmente esop se resuelve utilizando la funcion IF; La mayoría de SBGD's la tienen, supongo que interbase también.
__________________
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.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 16:40:02.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi