Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Manejo de Fechas Null y no Null (https://www.clubdelphi.com/foros/showthread.php?t=85086)

scigliano 27-01-2014 06:03:09

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

olbeup 27-01-2014 08:56:14

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

ecfisa 27-01-2014 22:58:24

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 :)

scigliano 28-01-2014 02:11:38

1 Archivos Adjunto(s)
Gracias olbeup y ecfisa, efectivamente tenia errores en lo que estaba haciendo :rolleyes: 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

scigliano 28-01-2014 06:32:10

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


La franja horaria es GMT +2. Ahora son las 06:15:47.

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