Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 27-01-2014
scigliano scigliano is offline
Miembro
NULL
 
Registrado: ago 2013
Posts: 10
Poder: 0
scigliano Va por buen camino
Unhappy Manejo de Fechas Null y no Null

Hola, como están…

Estoy trabajando con delphi 2010 y sql server 2005, y tengo rato dándole vuelta al siguiente problema:

Tengo un formulario con la ficha de trabajadores, donde si ya tienen definida la fecha de fin de su contrato, el usuario marca un CheckBox ‘Posee Fecha Fin de Contrato’ para que se active el campo donde debe indicar la fecha mencionada.
Por lo tanto, si hay fecha fin de contrato, se guardará el valor de la fecha, sino, se guardará un valor null.
Quisiera formatear el campo TEdit de la fecha así: ' / / ' para que el usuario no tenga que escribirlas, si lo hago con MaskEdit tendré problemas cuando no exista la fecha, osea, cuando sea null. Si utilizo DateTimePicker siempre me colocará una fecha, aún cuando el trabajador no posea fecha de fin de contrato.
En fin, que no sé cómo solucionar esto, si me pueden dar algunas ideas, se los agradezco.
En sql server 2005, el campo para las fechas es: DateTime, aunque si es necesario, lo manejaría a través de un Varchar.

Saludos
Responder Con Cita
  #2  
Antiguo 27-01-2014
Avatar de olbeup
olbeup olbeup is offline
Miembro
 
Registrado: jul 2005
Ubicación: Santiago de la Ribera (España)
Posts: 685
Poder: 19
olbeup Va camino a la fama
El problema aun no lo he entendido, yo utilizo SQL Server 2005 y las fecha utilizo MaskEdit (EditMask=!99/99/0000;1;_) y las fechas sean null o no, a la hora de recuperar comprueba que el año se mayor que 1900.

Un saludo
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber.
Responder Con Cita
  #3  
Antiguo 27-01-2014
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola scigliano, bien venido a Club Delphi .

Coincido con olbeup en que no está muy claro tu planteo...

Lo que interpreté es que hay dos campos en juego, uno que indica si posee fecha de fin de contrato (llamémosle "FIN_CONTRATO") y otro (llamémosle "FECHA") que, de estar el anterior en verdadero, almacena la fecha del mismo y en caso contrario deberá tener el valor NULL.

Si es así, yo haría por ejemplo:
Código Delphi [-]
// ( La propiedad EditMask es configurable desde el Object Inspector,
//  si previamente has creado los campos persistentes )
procedure TForm1.FormCreate(Sender: TObject);
begin
  DataSet.FieldByName('FECHA').EditMask:= '00/00/0000;1; ';
end;

// Evento OnDataChange del TDataSource asociado,
// aprovechado para activar/desactivar acciones sobre campo "FECHA"
procedure TForm1.DataSource1DataChange(Sender: TObject; Field: TField);
begin
  // ( DBEdit1: DataSource=DataSource1 / DataField="FECHA" )
  DBEdit1.Enabled:= Boolean(DataSet.FieldByName('FIN_CONTRATO').AsInteger);
  Button1.Enabled:= DBEdit1.Enabled;
end;

// Pone el campo "FECHA" en NULL
procedure TForm1.Button1Click(Sender: TObject);
begin
  if Boolean(DataSet.FieldByName('FIN_CONTRATO').AsInteger) then
  begin
    DataSet.Edit;
    DataSet.FieldByName('FECHA').Clear;
    DataSet.Post;
  end;
end;

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #4  
Antiguo 28-01-2014
scigliano scigliano is offline
Miembro
NULL
 
Registrado: ago 2013
Posts: 10
Poder: 0
scigliano Va por buen camino
Gracias olbeup y ecfisa, efectivamente tenia errores en lo que estaba haciendo otra novatada más....
Con las instrucciones de ecfisa pude corregir y ahora funciona bien

No sé si comentarlo aquí o debo abrir otro hilo -ustedes me corrigen-, al momento de estar digitando la fecha, si pulso la tecla TAB sin terminar de completar dia/mes/año, aparece el mensaje: 'Invalid Input Value. Use escape key to abandon changes'.
Hay alguna forma que yo pueda mostrar un mensaje con un texto más entendible para el usuario final cuando no completa la fecha correctamente?

Saludos
Imágenes Adjuntas
Tipo de Archivo: jpg Captura.JPG (20,7 KB, 4 visitas)
Responder Con Cita
  #5  
Antiguo 28-01-2014
scigliano scigliano is offline
Miembro
NULL
 
Registrado: ago 2013
Posts: 10
Poder: 0
scigliano Va por buen camino
Compañeros, encontré la solución a la consulta de cómo modificar el mensaje que genera el MaskEdit cuando la fecha está incompleta...
Aquí está el link donde aparece todo explicado:

Maskedit Invalid Input Value Use escape key to abandon change

Saludos

PD: Coloco el link así, porque me aparece un mensaje indicando que aún no tengo permitido poner enlaces...

Última edición por ecfisa fecha: 28-01-2014 a las 07:58:13. Razón: Ajustar enlace.
Responder Con Cita
Respuesta


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
Delphi + BDE + MSSQL SERVEr 2005 todas las fechas con en null DagariK MS SQL Server 2 28-10-2010 13:40:32
manejo de campos de datos null pmtzg Conexión con bases de datos 2 29-05-2008 02:47:17
DATETIMEPICKER no admite fechas NULL Jose Manuel Varios 4 05-05-2008 10:01:34
cambiar campo null a not null andressanchez Firebird e Interbase 8 18-09-2006 23:00:09
Null y UDF ARPE Firebird e Interbase 0 08-09-2004 11:56:20


La franja horaria es GMT +2. Ahora son las 19:35:44.


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