FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Resta equivocada...
Hola amigos foristas...
Bueno, la verdad esque estuvo un buen rato tratando de buscar un titulo descriptivo para esta pregunta pero me fue imposible encontrar alguno. Mi situacion es la siguiente: Estoy desarrolloando un aplicativo medianamente grande que esta dividido por modulos y en uno de ellos hay una opcion para hacer ajustes al inventario por articulos(ya sea por robo, porque se daño, caduco, aparecio, etc...), en esta opcion tu puedes escojer si deseas hacer una salida o entrada de dicho articulo. El hecho es que uno de los usuarios esta tratando de hacer una salida, mas exactamente esta tratando de sacar del inventario lo unico que queda de cierto artiulo(pongamole el codigo 11000701) que son 0.01 gramos (cosa que ya verifique en el reporte de saldos de inventarios y haciendo el respectivo query); en dicha opcion de ajuste hay una validacion para que no permite sacar mas de lo que hay(cosa que es perfectamente necesaria); el señor usuario digita 0.01 pero el sistema muestra la excepcion que controla que no se saque mas de lo que hay. Lo primero que se me vino a la cabeza fue "Quiza en la validacion dice if CantidadenBD <= CantidadDigitada then raise exception.create("No es posible"), haciendo que el 0.01 entre en dicho rango de error", asi que inmediatamente fui a verificar dicho pensamiento el cual resulto incorrecto pues decia , De manera pues que estaba bien... Luego dije "Caramba quiza el query a traido mal el resultado redondeandolo o que se yo", asi que comence a depurar y Ohhh sorpresa¡¡¡¡¡¡ lo hacia bien, asi que tengo un algoritmo asi:
Donde CantidadenBD es igual a : 0.01 y Donde CantidadDigitada es igual a : 0.01 Entonces, ¿Porque entra en esa condicion cuando no la cumple?, he hecho una prueba poniendo una variable llamada Resta y restandole CantidadenBD - CantidadDigitada y el resultado es -7.35689749e16, asi que repise manualmente todo el movimiento de las cantidades de dicho articulo en la BD y me sucede lo mismo, cambie el tipo de CantidadDigitada como Double, Extended, Real y tampoco, tambien intente Al llamar el query que me trae CantidadenBD como AsFloat, AsCurrency, y ninguna me funciono y por eso no entiendo que es lo que sucede... si tengo un algoritmo que me dice:
Esta es mi triste situacion , muchas gracias compañeros por su atencion prestada cualquier opinion seria muy valiosa. P.D. Motor = FireBird 1.5. Lenguaje = Delphi 5. Sistema operativo, donde se a probado = Windows 2000 y en Windows XP. Procesadores en los que se a probado = Intel y AMD.
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!" http://www.purodelphi.com/ http://www.nosolodelphi.com/ |
#2
|
||||
|
||||
¿Has mirado qué datos hay guardados exactamente en la fdb?
Te aconsejo que lo mires con herramientas como isql (la encontrarás en el directorio bin de firebird). Código:
c:\> isql SQL> connect "mibasedatos.fdb" user "sysdba" password "masterkey"; SQL> select codigo, precio, stock from tbTabla where codigo=3333; (el que busques) El verlo con ibexpert, marathon, etc. tiene el inconveniente de que te trunca los decimales por la máscara que tienen configurado en el programa. Ya nos contarás. |
#3
|
||||
|
||||
Muy bien amigo muchas gracias por tu atencion prestada, pero lamentablemente ese no es el problema pues aunque tenia dudas de que fuese esto debido a que como ya mencione habia repizado todas las cantidades. hice lo que mencionaste y sencillamente me muestra todos con 2 decimales y la suma me da 0.01.
Muchisimas gracias P.D. Aun sigo sin solucionarlo
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!" http://www.purodelphi.com/ http://www.nosolodelphi.com/ |
#4
|
||||
|
||||
Cita:
Código:
6.51600000000000 5.05500000000000 0.22555485454554 225.650000022210 2.23000000000000 |
#5
|
||||
|
||||
Cita:
Como te dice Casimito tu problema esta en los decimales, lo que pasa es vos estas viendo los datos redondeados. aunque dudo mucho que tu resultado sea -7.35689749e16, no será -7.35689749e-16 o 7.35689749e16?
__________________
[Crandel] |
#6
|
||||
|
||||
Bueno, mis compañeros, muchas gracias de nuevo por tu atencion.
Cita:
Cita:
De nuevo muchas gracias,
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!" http://www.purodelphi.com/ http://www.nosolodelphi.com/ |
#7
|
||||
|
||||
Cita:
Cita:
Posible solución: Redondear los datos. Proba algo asi: Código:
Round(numero*100)/100
__________________
[Crandel] |
|
|
|