PDA

Ver la Versión Completa : Ayuda con esta consulta?


danytorres
10-10-2003, 19:56:01
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.....

andres1569
10-10-2003, 20:29:15
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.