FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Delphi 5 y firebird 2.0.
Muchas gracias, seguimos invenstigando. |
#3
|
||||
|
||||
Haciendo unas sencillas pruebas con Firebird 1.5, veo que esta sentencia:
arroja un resultado de tipo entero de 1. Eso me sugiere que Firebird determina el tipo del resultado con base al tipo de los operandos, y tratándose de una división entre enteros, trunca las decimales del resultado. Así que hice esta otra prueba: Y el resultado fue, de tipo flotante, 1.5. Claro que en un caso real los operandos no son constantes, por lo que habría que hacer este molde de tipo si quisiéramos obtener el mismo resultado: (sustituyendo 90 por el campo, parámetro o variable Integer que deseamos dividir entre 60). Eso sería para que el resultado de la pura división fuese el correcto (flotante 1.5, no entero 1). Logrando lo anterior, el siguiente paso sería aplicar otro molde de tipo al resultado de la división: Con ello, el valor de 1.5 es redondeado hacia "arriba" (como aparentemente lo hacen por regla la mayoría, sino es que todos los motores de bases de datos), obteniéndose un valor entero de 2. Pero si lo que se desea NO es redondear el resultado de la división, sino extraer su parte entera, es decir, "truncarlo", hay que hacer algo más. Firebird 1.5 no cuenta con la función Trunc que menciona cdac901 (al menos no de forma nativa), y a partir de este punto me van a disculpar porque el SQL no es mi fuerte. Lo que se me ocurre es algo como esto: Hice una prueba y me arroja el esperado valor entero de 1. Ahora, queda la duda de por qué a Joe_Balda, la simple división de los enteros 90 / 60, que "debería" dar siempre un resultado entero de 1 (según se infiere con las pruebas que hicimos los demás compañeros), a él, con Firebird 2.0 le arroja un resultado de 2. Para confirmar lo que dije al comienzo, Joe_Balda y demás compañeros, ¿qué les aparece a ustedes con esta simple sentencia?
Un extraño saludo. Al González. |
#4
|
||||
|
||||
Select 90 / 60 From RDB$DataBase
Prueba con FB 1.5 me ha devuelto: 1.5 Prueba con FB 2.1 me ha devuelto: 1 |
#5
|
||||
|
||||
Cita:
A mi en FB 1.5.3 dicha consulta regresa 1. Y para comprobar lo dicho por Al:
Regresa 1,50 Por otro lado quiero aclarar que SI existe una función de redondeo para Firebird, desde FB 1.0 a versiones 1.5.x se debe utilizar la UDF TRUNCATE y/o I64TRUNCATE. Desde Firebird 2.1 existe TRUNC() y como es bien sabido la gran mayoría de las funciones fueron incorporadas desde "fábrica" al motor y no hay que estar registrándolas. Saludos, |
#6
|
||||
|
||||
Pues seguro, aquí va un pantallazo, espero que lo puedas ver:
|
#7
|
||||
|
||||
Hola,
Lo veo "fuerte y claro" Acabo de ver que tu prueba corre en un FB 1.5.5 ¿habrá cambiado algo entre 1.5.3 y 1.5.5 como para que hayan variado los resultados? ¿O será que IBExpert me lo redondeó solito? Voy a probar con una "conexión cruda" y directa con isql para sacarnos dudas. Saludos, |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Parte entera y decimal | joanajj | Varios | 6 | 16-01-2008 07:51:09 |
falla en división | mamaro | Firebird e Interbase | 11 | 12-02-2007 17:48:44 |
Parte entera | amedina | Varios | 1 | 20-08-2005 03:06:04 |
Como extraer parte entera de una fraccion | JODELSA | Varios | 3 | 23-05-2003 17:05:26 |
|