Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 10-10-2003
danytorres danytorres is offline
Miembro
 
Registrado: may 2003
Ubicación: Venezuela. Edo Carabobo
Posts: 361
Poder: 21
danytorres Va por buen camino
Post Ayuda con esta consulta?

Hola a todos los miembros del foro. En los actuales momentos necesito realizar una consulta de asistencia de entrada y salida, la tabla esta en Sql en la tabla tengo nombre, apellido hora de marcada, fecha el detalle esta es como se yo que dia no me bino esa persona por ejemplo este es una query de la asistencia de una persona;


code
_________________________
SELECT CEDULAUSUARIO, FECHA, HORA, OBSERVACION, TIPO, NOMBRE, APELLIDO
FROM HISTORIAL
WHERE (CEDULAUSUARIO = '8830467') AND (FECHA BETWEEN CONVERT(DATETIME, '2003-09-01 00:00:00', 102) AND CONVERT(DATETIME,
'2003-10-10 00:00:00', 102))
_____________________________________________


El resultado del query es el siguiente:

cedula fecha hora nombre apellido
--------------------------------------------------------------------
8830467 01/09/2003 7:19:50 pepe alvares
8830467 02/09/2003 8:19:50 pepe alvares
8830467 04/09/2003 7:19:50 pepe alvares
__________________________________________

si observan pepe no bino el 03/09/2003, lo que nesecito es que el query me coloque un registro indicando que falto el 03/09/2003, quedando de la siguiente forma


cedula fecha hora nombre apellido Observacion
--------------------------------------------------------------------
8830467 01/09/2003 7:19:50 pepe alvares
8830467 02/09/2003 8:19:50 pepe alvares
8830467 03/09/2003 0:00:00 pepe alvares ausente
8830467 04/09/2003 7:19:50 pepe alvares
__________________________________________

y que coloque una observacion en el campo 'Observacion' que diga ausente. Agradesco la ayuda?


____________________________________
Un saludo a todos.....

Última edición por danytorres fecha: 10-10-2003 a las 19:58:05.
Responder Con Cita
  #2  
Antiguo 10-10-2003
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 21
andres1569 Va por buen camino
Para implementar esto mediante SQL, lo único que se me ocurre es que crees una tabla de fechas, donde almacenes todas las fechas laborables, o cuando se supone que se podría asistir. De esta manera, cuando lanzas la consulta, lo haces mediante un LEFT OUTER JOIN, con tabla principal (LEFT) la de fechas. De esta forma, te mostrará todas las fechas "lectivas/laborales" y donde no haya asistido la persona, sus datos aparecerán como NULL (desde Delphi ya te puedes encargar de "adornar" esos NULLs poniendo lo de "Ausente", usando el método OnGetText del campo en cuestión):

SELECT CEDULAUSUARIO, FECHA, HORA, OBSERVACION, TIPO, NOMBRE, APELLIDO
FROM FECHAS F
LEFT OUTER JOIN HISTORIAL H ON (CEDULAUSUARIO = '8830467') AND
(H.FECHA BETWEEN (F.FECHAINICIO, F.FECHAFINAL))

La tabla FECHAS debería tener los campos FechaInicio y FechaFinal, que indicarían cada una la hora 0 y la hora 24 del mismo día (lo que en tu consulta aparecía como valores literales).

Ahora no se me ocurre otra cosa.
__________________
Guía de Estilo
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


La franja horaria es GMT +2. Ahora son las 08:08:13.


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