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 08-01-2009
Avatar de Alcolea
Alcolea Alcolea is offline
Miembro
 
Registrado: abr 2006
Ubicación: Santiago de Cuba, Cuba
Posts: 100
Poder: 19
Alcolea Va por buen camino
Question ¿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...

Código Delphi [-]
Form4.ADOQuery1.SQL.Add('Select Carne,Nombre,Apellido1,Apellido2,Fecha,VisitaA,HoraEntrada');
Form4.ADOQuery1.SQL.Add('From Dentro');     
Form4.ADOQuery1.SQL.Add('Where HoraEntrada BETWEEN '+'"'+'08:00:00'+'"'+' and '+'"'+'12:00:00'+'"');    
Form4.ADOQuery1.SQL.Add('order by Fecha');


... 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"

Última edición por dec fecha: 08-01-2009 a las 00:42:07.
Responder Con Cita
  #2  
Antiguo 08-01-2009
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Por lo general, este tipo de problemas se resuelven usando consultas parametrizadas. Pon tu consulta así:

Código SQL [-]
select Carne, Nombre, Apellido1, Apellido2, Fecha, VisitaA, HoraEntrada
from Dentro
where HoraEntrada between :inicio and :fin
order by fecha

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:

Código Delphi [-]
ADOQuery1.Parameters.ParamByName('inicio').Value := HoraInicio;
ADOQuery1.Parameters.ParamByName('fin').Value := HoraFin;

Aquí, HoraInicio y HoraFin deben ser valores de tipo TTime. Puedes obtenerlos a partir de una cadena de caracteres con la función StrToTime:

Código Delphi [-]
HoraInicio := StrToTime('08:00');
HoraFin := StrToTime('13:00');

Como estás trabajando con ADO, debes, además, especificar el tipo de datos de los parámetros:

Código Delphi [-]
ADOQuery1.Parameters.ParamByName('inicio').DataType := ftTime;
ADOQuery1.Parameters.ParamByName('fin').DataType := ftTime;

En resumen, tendrías algo así;

Código Delphi [-]
var
   HoraInicio, HoraFin: TTime;

begin
  
  ...

  HoraInicio := StrToTime('08:00');
  HoraFin := StrToTime('13:00');

  ADOQuery1.Parameters.ParamByName('inicio').DataType := ftTime;
  ADOQuery1.Parameters.ParamByName('fin').DataType := ftTime;

  ADOQuery1.Parameters.ParamByName('inicio').Value := HoraInicio;
  ADOQuery1.Parameters.ParamByName('fin').Value := HoraFin;

  ADOQuery1.Open;
end;

// Saludos
Responder Con Cita
  #3  
Antiguo 08-01-2009
Avatar de Alcolea
Alcolea Alcolea is offline
Miembro
 
Registrado: abr 2006
Ubicación: Santiago de Cuba, Cuba
Posts: 100
Poder: 19
Alcolea Va por buen camino
Gracias por la ayuda, usted siempre tan oporutno.
Responder Con Cita
  #4  
Antiguo 08-01-2009
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.410
Poder: 22
fjcg02 Va camino a la fama
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
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
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
Como pasar un DateTime a formato Horas? Jonathan96 SQL 13 15-01-2009 19:13:59
Formato .pgm ¿Como lo puedo pasar a .jpg? Delphius Varios 4 21-08-2007 20:58:07
Como pasar datos de una hoja de Excel a Bases de Datos de Paradox Goyo OOP 1 06-02-2007 01:57:20
Saber si una consulta no devuelve datos rafita SQL 4 18-09-2006 10:00:26
cual seria la mas adecuado base de datos... ronimaxh Firebird e Interbase 8 23-04-2004 17:47:15


La franja horaria es GMT +2. Ahora son las 16:55:01.


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