Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 07-03-2011
Efren2006 Efren2006 is offline
Miembro
 
Registrado: feb 2006
Posts: 172
Poder: 19
Efren2006 Va por buen camino
Problemas de Calculo con decimales

Tengo el Siguiente Problema

Tengo un procedimiento almacenado donde debo calcula un factor que resulta de la Division de 2 campos, al parecer algo simple, pero al realizarla siempre me da CERO, ya verifique que los campos tiene valor, incluso haciendo una Consulta igualmente me arroja CERO, coloco algo del Codigo;

Código SQL [-]
 
DECLARE VARIABLES XFACTOR NUMERIC(18,5);
DECLARE VARIABLES DIASPAGO INTEGER;
DECLARE VARIABLES DIASANO INTEGER;
..
..
XFACTOR =0;
SELECT DIASPAGO,DIASANO FROM PARAMETRO
INTO  IASPAGO,IASANO;
// DIASPAGO=15  esto son los valores 
// DIASANO=360
XFACTOR = (DIASPAGO/ DIASANO);
..
..
EL VALOR DE XFACTOR ME DA CERO...


Probe incluso haciendo una Consulta

Código SQL [-]
 
select DIASPAGO/ DIASANO from PARAMETRO
Igual el resultado es CERO.

Nota: Uso Firebird 2.1

Gracias por su aporte..
Responder Con Cita
  #2  
Antiguo 07-03-2011
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Hola.

Te recomiendo leer este hilo, sobre todo el mensaje 27:

http://www.clubdelphi.com/foros/showthread.php?t=72413

Cuando es una división entero / entero, el estándar SQL dice que deben eliminarse las decimales del resultado (según el documento de Firebird ahí enlazado).

Saludos.

Al González.
Responder Con Cita
  #3  
Antiguo 08-03-2011
Efren2006 Efren2006 is offline
Miembro
 
Registrado: feb 2006
Posts: 172
Poder: 19
Efren2006 Va por buen camino
Cita:
Empezado por Al González Ver Mensaje
Hola.

Te recomiendo leer este hilo, sobre todo el mensaje 27:

http://www.clubdelphi.com/foros/showthread.php?t=72413

Cuando es una división entero / entero, el estándar SQL dice que deben eliminarse las decimales del resultado (según el documento de Firebird ahí enlazado).

Saludos.

Al González.
Amigo Al Gonzalez.. ya entendi el problema,,, debo cambiar las variables tipo Entero a Numeric (Float) para logra el objetivo.

Gracias por el aporte...
Responder Con Cita
Respuesta



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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Calculo con decimales Carlos Arevalo Varios 3 30-07-2008 18:12:27
Problemas con Calculo entre Fechas CamiloU OOP 2 03-04-2006 23:48:51
Problemas con decimales tbolzan Conexión con bases de datos 3 23-11-2005 12:12:09
Problemas en un calculo con Zeos en mysql... uper MySQL 1 26-10-2005 23:38:15
Problemas de calculo en Procedimientos Olympus Firebird e Interbase 7 20-05-2003 00:38:23


La franja horaria es GMT +2. Ahora son las 12:56:04.


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