Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-09-2007
Avatar de silver07
silver07 silver07 is offline
Miembro
 
Registrado: jul 2007
Posts: 42
Poder: 0
silver07 Va por buen camino
Question Comparación de Fechas

Hola a Todos, estoy trabajando en un sistema en el cual tengo una tabla llamada "actividades", donde tengo un campo llamado "Estatus", por el cual guardo las siguientes informaciones (Pendiente, Finalizada y Nulo) y un campo llamado "FechaFin", en este registro las fechas futuras donde terminara la actividad o el día futuro donde se realizará. El asunto es que no sé como hacerle para que en el campo estatus de forma automática me grabe "Finalizada" una vez la Fechafin sea mayor a la registrada, he estado buscando en internet pero si éxito. Un ejemplo de esto sería algo más o menos como esto:

Si creo una actividad con fecha para el 20/10/2007 que una vez pasada esta fecha, como 21/10/2007 se registre como "Finalizada".


Espero haberme explicado bien, muchas gracias anticipada...
Responder Con Cita
  #2  
Antiguo 25-09-2007
Avatar de rodrigodeoz
rodrigodeoz rodrigodeoz is offline
Miembro
 
Registrado: sep 2007
Posts: 30
Poder: 0
rodrigodeoz Va por buen camino
Smile

Mira es algo muy sencillo, tendrias que implementar un codigo que te haga una busqueda por fecha, que seleccione y actualize todos los registros que esten en estatus=pendiente y que la fecha sea menor a fecha actual, mira seria asi:

UPDATE actividades SET Estatus='Finalizada' where FechaFin<:fecha and Estatus='Pendiente';
Responder Con Cita
  #3  
Antiguo 25-09-2007
Avatar de silver07
silver07 silver07 is offline
Miembro
 
Registrado: jul 2007
Posts: 42
Poder: 0
silver07 Va por buen camino
Question Asunto

Disculpa mi ignorancia, como novato al fin que soy, dónde habría de colocar esa sentecia, en algún evento del form , la tabla, etc?

Muchas gracias por tu tiempo...
Responder Con Cita
  #4  
Antiguo 25-09-2007
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
La logica dice que si buscas que se haga en automatico, este deberia estar en el from create, para que revise la tabla y la actualice al iniciar el programa, otra seria hacerlo en un boton, un timer etc, etc.
Saludos
Responder Con Cita
  #5  
Antiguo 25-09-2007
Avatar de rodrigodeoz
rodrigodeoz rodrigodeoz is offline
Miembro
 
Registrado: sep 2007
Posts: 30
Poder: 0
rodrigodeoz Va por buen camino
Cita:
Empezado por silver07 Ver Mensaje
Disculpa mi ignorancia, como novato al fin que soy, dónde habría de colocar esa sentecia, en algún evento del form , la tabla, etc?

Muchas gracias por tu tiempo...
Como comento Caral puedes ponerla en el meto oncreate del Form pero yo te recomiendo lo pongas en el onshow del form
Responder Con Cita
  #6  
Antiguo 26-09-2007
Avatar de silver07
silver07 silver07 is offline
Miembro
 
Registrado: jul 2007
Posts: 42
Poder: 0
silver07 Va por buen camino
Unhappy Asunto

Disculpa las molestias, pero no me funciona.... no me permite compilar el programa

Lo coloque de esta forma en el eveto [OnShow] del form, luego lo probé en el evento [OnCreate] del form y tambien utilice un Timer y nada:

Código Delphi [-]
UPDATE Dmodulo.tblactividades SET estatus='FINALIZADA' where FechaFin<:fecha and estatus='PENDIENTE';

y me presenta el siguiente error:

Cita:
[Error] RegistroActividades.pas(102): Missing operator or semicolon
[Error] RegistroActividades.pas(102): Statement expected, but expression of type 'TADOTable' found
[Fatal Error] Sisconem.dpr(21): Could not compile used unit 'Formularios\RegistroActividades.pas'
Acaso me faltó algo?
Responder Con Cita
  #7  
Antiguo 26-09-2007
Avatar de rodrigodeoz
rodrigodeoz rodrigodeoz is offline
Miembro
 
Registrado: sep 2007
Posts: 30
Poder: 0
rodrigodeoz Va por buen camino
Cita:
Empezado por silver07 Ver Mensaje
Disculpa las molestias, pero no me funciona.... no me permite compilar el programa

Lo coloque de esta forma en el eveto [OnShow] del form, luego lo probé en el evento [OnCreate] del form y tambien utilice un Timer y nada:


Código Delphi [-]
UPDATE Dmodulo.tblactividades SET estatus='FINALIZADA' where FechaFin<:fecha and estatus='PENDIENTE';





y me presenta el siguiente error:



Acaso me faltó algo?
por que mejor no utilizas un componente Query o ADOQuery no se con que componentes estas trbajando y le pones la consulta en la propiedad SQLstring y donde lo mandes a llamar la pones
Código Delphi [-]
   Dmodulo.query.params.parambyname('fecha').value:=now;
   Dmodulo.query.Execsql;
 
esto es para un componente Query, el codigo siguiente es para un componente ADOQuery
 
   Dmodulo.ADOquery.parameters.parambyname('fecha').value:=now;
   Dmodulo.ADOquery.Execsql;
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
Problema con FTP.....comparacion P2P JuanErasmo Internet 0 12-09-2007 18:11:17
Optimizar comparación de fechas kuan-yiu Varios 11 27-07-2006 10:11:02
comparación de fechas Nelly Varios 2 27-10-2005 17:30:42
Comparación de Fechas sierraja Varios 5 19-06-2005 06:56:20
Comparacion Decimal wpolanco Varios 1 30-07-2003 00:41:32


La franja horaria es GMT +2. Ahora son las 16:04:11.


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