FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Problema con la fecha en Firebird
Buenas a todos después de mucho tiempo sin dar la lata.
Tengo el siguiente problema. Intento hacer una consulta filtrando por una facha determinada donde uso un datatimer que me devuelve la fecha en el formato: dd/mm/yyyy y este valor lo paso como parámetro al select. En el dataset de FBIPLus Trial tengo configurado el formato dd/mm/yyyy. Hasta ahí bien, pero el problema es que Firebird me está tomando la fecha de otro modo: mm/dd/yyyy y claro me dá error de conversión de fecha. He probado a poner directamente en: ...... WHERE FECHAA='23/12/2002', y dá el mismo error. Uso Dialect 3, FBIplus Trial, Firebird... Por más que busco no veo donde puede estar el problema. Si alguien tiene alguna información se agradece... saludo... |
#3
|
|||
|
|||
Ya lo he hecho
Eso ya lo he hecho, pero es como si inviertiera mes y día.
ese 30.04.2006 lo considera como 04.30.2006. Si uso MDO RC2 o los componentes de Interbase de Delphi ese problema no existe... Es raro... |
#4
|
|||
|
|||
El lenguaje sql exige que el formato de la fecha sea m/d/Y de modo que es normal que se interpreten las fechas de esa forma (tambien valdria Y/m/d).
Lo raro es que digas que con los componentes de interbase de delphi no se da el problema, ya que es exactamente igual. Lo que hay que hacer es o usar parametros en las querys, que es la forma correcta de trabajar con las bases de datos, de modo que la conversion al formato necesario las hagan los propios componentes, o formatear las fechas con el formato m/d/y antes de construir la sentencia sql. Saludos |
#5
|
|||
|
|||
Cordial saludo,
Bueno, las fechas siempre han sido un problemilla, debido a que una cosa es la representacion interna en el motor, otra cosa es la forma en que se utilizan en SQL y otra es como se la presentamos al usuario. Sobre la representacion interna, dejemosela a algun experto. Para la presentacion de datos al usuario, en mi caso (creo que es el de varios) utilizo el formato dd/mm/yyyy, pero en sentencias SQL se utiliza mm/dd/yyyy. Para los que prorgramamos en Delphi y debemos construir SQL al vuelo, tendremos problema con variables de tipo TDateTime (son las que utilizo para mis variables en Delphi que tengan fechas). Por eso diseñe una funcioncita que me convierta los TDateTime en una cadena con la fecha en el formato mm/dd/yyyy.
Espero les sea de utilidad. Luis F. Buelvas T.
__________________
Luis Fernando Buelvas T. |
#6
|
|||
|
|||
Gracias por las respuestas
Gracias a todos, en cualquier caso mantengo lo que dije, usando los componentes de Interbase o los MDO(mercury) no sucede ningún problema y puedo visualizar y pasar como parámetro a la SQL la fecha en formato dd/mm/yyyy el problema me lo da con las FIBplus,que se los tengo que pasar mm/dd/yyyy .
Un saludo.... |
#7
|
||||
|
||||
Cita:
Espero que funcione, pues no lo he probado. Pero como he dicho en otros hilos, es mejor utilizar parametros para asignar cualquier fecha. Asi el componente y la BBDD se encargan del trabajo sucio de conversion.
__________________
Van Troi De León (Not) Guía, Code vB:=Delphi-SQL, ¿Cómo? Viajar en el tiempo no es teóricamente posible, pues si lo fuera, ya estarían aqui contándonos al respecto! |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Guardar null (nolo) en un campo fecha en Firebird | cahosoft | Conexión con bases de datos | 3 | 19-04-2014 09:54:17 |
Error al hacer insert (campo fecha) en firebird con fibplus | Acanol | Firebird e Interbase | 7 | 15-06-2006 09:05:07 |
Problema con la Fecha | ramonibk | Varios | 1 | 28-02-2005 19:30:29 |
Formato fecha en Firebird 1.5.1 | mosorio | Firebird e Interbase | 1 | 05-11-2004 17:23:46 |
Formato fecha en FireBird | HombreSigma | Firebird e Interbase | 2 | 22-06-2003 22:18:00 |
|