![]() |
¿Cómo saber el formato adecuado de los datos para hacer una consulta?
Hola a todos.
Estoy tratando de hacer una consulta desde Delphi7 a una BD de Access que manejo con mi aplicación donde deseo tener un grupo de registros dado un rango de horas determinadas...
... ya he puesto la hora de varia maneras por ejemplo "30/12/1899 08:00:00", "08:00:00", "08:00" y siempre me devuelve este mensaje "No coinciden los tipos de datos en la expresión de criterio". Supongo, como ya me sucedió con las fechas, que esté dado por la manera que SQL interpreta el formato de la hora y es entonces que quisiera saber donde puedo ver cual es formato adecuado para pasar el dato. En Access utilizo el formato de Hora corta (12:20) para este campo y el Delphi7 veo los datos de esta manera "30/12/1899 12:20" |
Por lo general, este tipo de problemas se resuelven usando consultas parametrizadas. Pon tu consulta así:
Los dos puntos en :inicio y :fin indican que inicio y fin son parámetros. El valor de los parámetros los asignas antes de abrir la consulta:
Aquí, HoraInicio y HoraFin deben ser valores de tipo TTime. Puedes obtenerlos a partir de una cadena de caracteres con la función StrToTime:
Como estás trabajando con ADO, debes, además, especificar el tipo de datos de los parámetros:
En resumen, tendrías algo así;
// Saludos |
Gracias por la ayuda, usted siempre tan oporutno.
|
Hola,
Además de como ya te han indicado ( con parámetros ) si quieres incluir directamente las fechas en la consulta, creo recordar que en access es con en caracter #, #01/01/2009# Además, creo que en access las fechas siempre se guardan en formato dd/mm/aaaa hh:mm:ss. Tengo la duda de si es en access y en SQL Server. Por lo tanto, para filtrar un rango de un día tienes que tener en cuenta que la fecha 01/01/09 significa "01/01/09 00:00:00", lo que ha veces provoca que los resultados no sean los esperados. Unas pruebitas rápidas te sacarán de dudas. Saludos |
La franja horaria es GMT +2. Ahora son las 19:10:12. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi