Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 29-01-2007
Sara Paz Sara Paz is offline
Registrado
 
Registrado: ago 2004
Ubicación: Sevilla
Posts: 6
Poder: 0
Sara Paz Va por buen camino
Talking Problemas al guardar HORA

Saludos.
Uso DELPHI 6, FIREBIRD 1.5 y componentes de acceso a la BD FIBPLUS.
Se me plantea el siguiente problema.
Campo HORA, tipo TIME en una tabla cualquiera.
Desde código Delphi, en el evento AfterInset del componente de la tabla hago tbl_MyTablaHORA.Value := Now;. Al insertar un registro, se presenta el valor correcto en pantalla, p.e. las 16:30:40. Pues bien, al hacer el Post del registro el valor cambia a 7:29:15, que es exactamente el tiempo que falta hasta las 23:59:59. Siempre se reproduce este comportamiento.
He comprobado que a la base de datos le llega el valor cambiado, por lo que el problema deberá estar en el programa y/o sus componentes.
Si dejo el campo HORA sin asignar, como en un Trigger BeforeInsert de la tabla tengo puesto IF (NEW.HORA IS NULL) THEN NEW.HORA = CURRENT_TIME, todo va bien. Pero no puedo asignar un valor desde el programa porque cambia el valor según lo explicado anteriormente.
¿Alguien ha tenido un problema parecido o puede darme una explicación del porqué de este comportamiento aparentemente anormal?.
Gracias.
Sara Paz.
Responder Con Cita
  #2  
Antiguo 11-02-2007
Sara Paz Sara Paz is offline
Registrado
 
Registrado: ago 2004
Ubicación: Sevilla
Posts: 6
Poder: 0
Sara Paz Va por buen camino
Solucionado el problema. Comunico la solución enviada por el Equipo de Desarrollo de FIBPlus para conocimiento general de aquellos que usen estos componentes.

Hay que hacer lo siguiente:
  • Modificar el codigo de:
unit FIBQuery;
method
function TFIBXSQLVAR.GetAsDateTime: TDateTime;
  • Reemplazar las siguientes líneas:
SQL_TIMESTAMP:
begin
Result:=
PISC_QUAD(FXSQLVAR^.sqldata)^.gds_quad_high-IBDateDelta+
PISC_QUAD(FXSQLVAR^.sqldata)^.gds_quad_low/MSecsPerDay10;
end;
  • Por estas otras:
SQL_TIMESTAMP:
begin
Result:=
HookTimeStampToDateTime(AsTimeStamp);
end;
  • Abrir desde Delphi FIBPlus6.dpk y compilar.
Saludos.
Sara Paz.
Responder Con Cita
  #3  
Antiguo 11-02-2007
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.038
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Gracias por compartirlo
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
Problemas con la hora CoCaInE SQL 4 26-09-2006 09:09:46
problemas a la hora de abrir un ClientDataset jmlifi Conexión con bases de datos 4 01-06-2006 12:28:20
problemas con la hora Nelly Varios 1 17-11-2005 08:53:07
Problemas a la hora de actualizar el Delphi Pack bustio DelphiPACK 1 10-03-2005 18:19:09
Problemas con el Alias a la hora de Istalar mi aplicacion at12 Conexión con bases de datos 2 23-07-2003 12:56:25


La franja horaria es GMT +2. Ahora son las 07:43:33.


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