FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Como determinar Minutos y Segundos Exactos en Firebird????
Como se darán cuenta ando lidiando con los campos TIME en firebird, estoy haciendo un select de los retardos en horas, minutos y segundos de los empleados , pero veo que no me da exacto el dato, por ejemplo, les añado el siguiente Select, donde intento decifrar , cuanto tiempo en Horas y Minutos exacto pudiera tener X empleado:
Ejemplo1: Si la hora de entrada son a las 8am y si X empleado checa a las 08:12:40 am en la sentencia me desglosa el resultado = >>>> 12.6666 Mins. en vez de mostrar 12.40 Mins Ejemplo2: Si la hora de entrada son a las 8am y si X empleado checa a las 09:40:00 am en la sentencia me desglosa el resultado = >>>> 1.6777 Hrs. en vez de mostrar 1.40 Hrs. Agradezco cualquier sugerencia....
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
#2
|
|||
|
|||
Cita:
Salud OS
__________________
"La forma de empezar es dejar de hablar y empezar a hacerlo." - Walt Disney |
#3
|
||||
|
||||
¡Hola a todos!
Opino lo mismo que Eliseo, Alfredo. Recuerda que lo normal de cualquier lenguaje de programación (incluyendo SQL), es tomar las operaciones matemáticas de suma, resta, multiplicación y división bajo un esquema de base decimal. No puedes esperar que Firebird convierta el resultado automáticamente a base 60. Pero dicha conversión no tiene nada de ciencia, puedes hacerla tú mismo con una simple regla de tres. Si a 1 unidad de minuto le corresponden 60 segundos, ¿cuántos segundos corresponden a 0.6666 minutos? Código:
1 0.6666 --- ------- 60 ? O lo que es lo mismo, 0.6666 * 60 = 39.996 (redondeado, 40 segundos). Multiplica la fracción de minuto por 60 y obtendrás su representación en segundos. Multiplica la fracción de hora por 60 y obtendrás su representación en minutos. Espero te sirva de algo. Saludos. Al. Última edición por Al González fecha: 20-02-2008 a las 23:02:24. |
#4
|
||||
|
||||
Cita:
Gracias por sus sugerencias, que tengan buen día.
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
#5
|
||||
|
||||
Las Rfunc no te van a dar el resultado que quieres, pero ayudan bastante.
(En FB2 ya se han implementado algunas de las funciones de rfunc.) Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#6
|
||||
|
||||
Cita:
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
#7
|
|||
|
|||
Tambien con campos calculados
Código:
procedure TFFullDiariDM.QHoresRCalcFields(DataSet: TDataSet); var TotalMinuts,Hores,Minuts : Integer; begin TotalMinuts := Round(SecondsBetween(QHoresRSurt.AsDateTime,QHoresREntra.AsDateTime)/60); Hores := Trunc(TotalMinuts / 60); Minuts := Trunc(TotalMinuts mod 60); QHoresRHores.AsString := IntToStr(Hores) + ':' + FormatFloat('00',Minuts); end;
__________________
Gabriel |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Es posible determinar si el servicio del firebird se esta ejecutando? | Ricardo León | Conexión con bases de datos | 1 | 18-09-2007 18:35:27 |
Como determinar la ip de un pc | JoeyJordison | Varios | 1 | 14-01-2007 18:13:06 |
Trabajar con angulos (grados, minutos, segundos) | onlytk | Varios | 6 | 15-11-2005 23:49:33 |
como determinar el navegador por defecto | Velia | API de Windows | 4 | 13-11-2005 16:54:10 |
minutos y segundos con Tmediaplayer | Pepetrueno | Varios | 2 | 25-06-2003 22:07:48 |
|