Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MS SQL Server
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

 
 
Herramientas Buscar en Tema Desplegado
  #15  
Antiguo 24-07-2007
Avatar de nuk3zito
nuk3zito nuk3zito is offline
Miembro
 
Registrado: ago 2003
Ubicación: "Z" Land
Posts: 244
Poder: 23
nuk3zito Va por buen camino
Cita:
Empezado por JCarlosas
Para este caso me queda la duda tambien en caso de que necesite especificar la hora. ¿Como seria el formato:? ¿¿¿´yyymmdd hh:nn:ss´????

Nota: Por nn me referi a los minutos
Saludos a todos
JCarlos
OK, Ya estamos de acuerdo en que el formato ANSI para fechas es yyyymmdd.
Bueno, para horas solo existe un formato (pudiéramos hacer de cuenta que es el ANSI en vista de que no conozco otro, sáquenme del error en caso de estar mal informado) y es el hh:mm[:ss] como lo muestra el siguiente ejemplo.

Código:
  AdoQuery.SQL.Add('select * from Movimientos');
  AdoQuery.SQL.Add('where fechahora >= ''20070724 10:00''');
  AdoQuery.Open;
O sea, esta instrucción nos regresa los registros con fecha y hora mayor o igual al 24 de Julio de 2007 a las 10:00 a.m.

Sin embargo, si estamos creando estas consultas desde Delphi debo admitir que no me gusta para nada usar las horas de esta manera en el SQL Server. Lo hago como sigue:
Cuando utilizo solo fechas en un query, efectivamente utilizo el formato ANSI.
Cuando se trata de mezclar fechas y horas, yo prefiero enviarlo como un parámetro al componente, y dejar que el Delphi se encargue de hacer el trabajo sucio (Sin embargo, es válido hacerlo como especifiqué en el ejemplo anterior).
Para que no haya dudas, les pondré el ejemplo de la alternativa que pueden seguir (y se evitan de broncas porque es más engorroso construir la cadena de fecha y hora y luego enviarlo a la consulta ):
Código:
var
  dtFechaHora: TDateTime;
begin
  dtFechaHora:= EncodeDate(2007, 7, 24) + EncodeTime(10,0,0,0);
  // tambien así es válido
  dtFechaHora:= EncodeDateTime(2007, 7, 24, 10, 0, 0, 0);
  ...
  AdoQuery.SQL.Add('select * from Movimientos');
  AdoQuery.SQL.Add('where fechahora >= :FechaHora ');
  AdoQuery.Parameters.ParamByName('FechaHora').Value:= dtFechaHora;
  AdoQuery.Open;
Espero haber podido darles una orientación.
__________________
Tiempo y ocasión acontecen a todos!
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
Formato de fecha GustavoCruz SQL 8 26-06-2007 04:39:11
Formato fecha Io Varios 2 22-08-2006 13:55:04
formato de fecha ebeltete Varios 2 22-06-2006 16:36:26
Como cambiar el formato de un QRSysData en formato fecha Bitbanner Tablas planas 1 13-02-2005 12:33:26
Como Obviar el formato de Fecha del Servidor para Salvar sólo en formato "dd/mm/yyyy" R_Richards Varios 4 07-02-2005 15:57:19


La franja horaria es GMT +2. Ahora son las 21:16:44.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi