FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Tratamiento de fechas en Firebird
Creo que puse este Post en el lugar incorrecto, pido por favor a algún moderador que lo mueva a su lugar correspondiente.
Bueno, resulta que quiero traer un campo de tipo fecha desde Firebdir 2.1 hacia mi formulario., hago lo siguiente
El caso es que cuando me tiene que devolver la fecha (o sea que e.fecha < 2011/12/31 --> lo pongo de la forma aaaa/mm/dd porque es la única forma que Firebird me hace la comparativa correctamente), lo hace de la siguiente manera: 2009-10-30; yo quiero que me lo devuelva de la forma: 30/10/2009 que es como el usuario lo cargó en la BD y como figura en las tablas. Bueno, esto me está causando un problema, ¿alguien sabe la manera de arreglarlo para que Firebird me devuelva bien las fechas? Gracias, Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. Última edición por santiago14 fecha: 17-01-2013 a las 00:18:20. Razón: Errores de ortografía |
#2
|
||||
|
||||
Encontré una forma, aunque poco elegante a mi entender, funciona muy bien.
Esto está muy bien, pero el problema sigue cuando hago un LIST() de fechas, me las muestra al revés.... Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#3
|
||||
|
||||
Esa fecha está bien. Es una fecha en formato ISO.
Otra cosa es como quiera uno que se muestre en la pantalla. Por ello la siguiente pregunta: ¿esa consulta la tienes asociada a un conjunto de datos, cuyo campo de fecha (el resultado de la consulta) muestras en algún formulario? ¿Qué razón hay para hacer trabajar al servidor (y a la conexión de red) encargándole devolver la cadena 'Fecha es mayor a 2011'? Quizá una mejor idea sería emplear un campo fecha normal y usar en Delphi su evento OnGetText para condicionar qué es lo que debe mostrar o cómo debe mostrarlo. Saludos. |
#4
|
||||
|
||||
Cita:
Igualmente, usando EXTRACT se arregla. En este caso, la consulta se hace a través de un MDOQuery y luego la mando a una grilla para que se puedan ver los datos. Gracias.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#5
|
||||
|
||||
Cita:
Si el problema es entonces de mera presentación, tan sólo basta que le indiques al campo, a través de su propiedad DisplayFormat, el formato que debe usar, por ejemplo: dd/mm/yyyy. Lo más fácil es hacerlo con el inspector de objetos, y también se puede por código:
Espero haberme explicado. |
#6
|
||||
|
||||
Exacto, ahora sí.
Les comento como me fue cuando haga las pruebas pertinentes. Gracias, Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#7
|
||||
|
||||
El problema radica en la forma como trata el mensaje:
Ahí se maneja un solo tipo de dato, firebird en ese IIF hace un cast sobre "e.fecha" y lo regresa como varchar ya que el texto 'Fecha es mayor a 2011' no lo puede tratar como tipo fecha,así pues al dar displayFormat a el texto creo que sacará una excepción...
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H" |
#8
|
||||
|
||||
Claro, pero la sugerencia de usar DisplayFormat es con un campo de fecha normal, a raíz de que Santiago dijera que se trataba más bien de una cuestión de formato / presentación.
|
#9
|
||||
|
||||
Bueno, siguiendo con el tema, les mando una consulta en la cual muestro una lista de fechas armada con LIST.
Los resultados salen de la forma: aaaa-mm-dd, yo quisiera que salgan de la forma dd-mm-aaaa, pueden ver el resultado en el .jpg adjunto. Gracias, Santiago.
La verdad es que encuentro inquietante no poder configurar la salida de las fechas a la manera que yo necesite. Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#10
|
||||
|
||||
Acabo de encontrar una forma, está buena...
Con esto se me soluciona un drama, por lo menos en el LIST, bastante grande. Todos mis clientes me andan reclamando que tienen que "mirar la fecha de atrás para adelante". Envío el adjunto con el resultado. Gracias a todos por su atención. Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#11
|
||||
|
||||
Pero es que eso se soluciona muy fácil con la propiedad DisplayFormat tal como te lo han recomendado antes. Se ve que no has prestado atención al hilo.
En como interprete internamente las fechas firebird déjalos a los componentes, que bien saben hacer su trabajo. Ese esfuerzo inútil en hacer una consulta para "armar" la fecha como gustas se puede ahorrar. Tu error está en concebir que las fechas se ingresan a tu forma. No... cada motor tiene la propia y si no la respetas allí tu. Es por eso que los componentes ya disponen de las funcionalidades para solventar todo esto. Por ejemplo, quieres pasar una fecha pues basta con un:
Siendo MiFechaHora una variable del tipo TDateTime, o si quieres algo directo le puedes pasar desde un TDtateTimePicker por ejemplo:
Ahora no interesa el formato de presentación que tengas... si es mm/dd/yyyy o yyyy/aa/mm o el que fuese. Los componentes se encargan del trabajo sucio y traducen este formato al interno que espera la base de datos. A la inversa, al momento de presentar o leer los datos hay varias posibilidades de como encararlo. Puedes aprovechar el evento OnGetText o más fácil aún la propiedad DisplayFormat. También esto aplica a los parámetros. En tu consulta se ve en el where un Between. ¡Pasa los datos como parámetros!
Luego en tus parámetros les asignas los valores. Los parámetros harán el trabajo sucio y al final traduciran al formato adecuado que interprete Firebird. Y si dicha evaluación con las fechas será fija, aprende y comprende que debes ceñirte al formato interno (que en el caso de Firebird es: dd.mm.yyyy hh:mm:ss.nnnn) en lo más posible ya que no obligas al motor que interprete, o mejor dicho intente, reconocer si lo escrito cumple con alguno de los formatos (véase la tabla 10-2) que es capaz de aceptar ya que con eso pierdes tiempo. Esa consulta tarde o temprano será lentísima. Ha decir verdad no se comprende ni hay una razón fundada que te impida seguir las recomendaciones que te han dado. No me queda otra explicación más que tu ignorancia sobre el tema y el desconocimiento, y asombro de tu parte, al notar el porqué firebird guarda "una fecha extraña" y en una cerradez de que "debe almacenar siempre como y lo que ingreso". No sabía que los campos de un motor de base de datos deban ser WYSIWYG. ¿O acaso tienes alguna explicación al respecto? Saludos, |
#12
|
||||
|
||||
Cita:
Cita:
Estoy probando el asunto de DisplayFormat, gracias nuevamente. Un saludo Delphius, desde Salta a otro salteño. Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
#13
|
||||
|
||||
El displayFormat tampoco funcionará en esta consulta, ya que el list manda una cadena de texto, en este caso una o más de una fecha separada por comas, o mejor dicho, sí hay una sola fecha se podría tratar el dato como tipo Date y Delphi se encargaría solito de darle el formato según el PC en que se ejecute, pero acá no va a pasar eso ya que existe la pocibilidad (muy alta creo yo) de tener varias fechas sumario, por lo cual el que se encarga de hacer el cast de el campo tipo Date a varchar es Firebird y por lo tanto mandara un texto ordenado por año, mes día separado por guiones... sería bueno ver si Firebird tiene algo similar al DisplayFormat de Delphi aunque en el FAQ recomiendan hacer algo muy similar a extract
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H" |
#14
|
||||
|
||||
Cita:
Tengo varios casos en donde debo presentar una lista de fechas. Santiago.
__________________
Uno es responsable de lo que hace y de lo que omite hacer. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Manejo de Fechas en Firebird 2.1 | Jose Roman | SQL | 3 | 17-02-2009 18:15:03 |
Firebird dialect 3 y fechas | IVAND | Firebird e Interbase | 5 | 17-09-2008 20:16:48 |
firebird y fechas | jmlifi | Varios | 4 | 05-09-2007 10:54:59 |
Fechas en Firebird | Puche | Firebird e Interbase | 3 | 27-07-2006 11:09:52 |
Formato de fechas en FireBird 1.5 | defcon1_es | Firebird e Interbase | 1 | 02-04-2004 18:02:52 |
|