Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 28-04-2004
PTW PTW is offline
Miembro
 
Registrado: abr 2004
Posts: 55
Poder: 21
PTW Va por buen camino
control sobre DBEDit

Tengo un componente DBEdit asociado al campo de una tabla. Este campo es un campo de tipo monetario. Cuando pulso un boton "Modificar" del formulario, puedo modificar el contenido de dicho campo

El problema ocurre cuando al introducir datos en el DBEdit, escribo una cantidad monetaria incorrecta (por ejemplo: 212,2,,2).

En el evento OnExit del DBEDit habia intentado controlar que me mostrara un mensaje de error si se introducia una cantidad en un formato incorrecto, pero no llega a ejecutarse dicho codigo (este codigo lo he utilizado en componentes Edit, y funciona correctamente, pero en el DBEdit no).

¿Como lo hago?

Muchas gracias
Responder Con Cita
  #2  
Antiguo 28-04-2004
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Se trata realmente de un campo del tipo TFloatField????
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #3  
Antiguo 28-04-2004
PTW PTW is offline
Miembro
 
Registrado: abr 2004
Posts: 55
Poder: 21
PTW Va por buen camino
No he entendido tu pregunta.

Es una tabla Access con un campo "precio" que es de tipo Moneda,y el DBEdit esta asociado a ese campo. Y es un campo que almacena valores en forma de Euro (ejemplo: 25,20, 3,23,......) osea con "," com oseparador decirmal y 2 numeros decimales
Responder Con Cita
  #4  
Antiguo 28-04-2004
PTW PTW is offline
Miembro
 
Registrado: abr 2004
Posts: 55
Poder: 21
PTW Va por buen camino
y el problema no es por utilizar "," en vez de ".". Se produce cuando intentas introducir una cantidad monetaria con mas de una coma (ej: 2,2,33)


GRacias
Responder Con Cita
  #5  
Antiguo 28-04-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por PTW
el evento OnExit del DBEDit habia intentado controlar que me mostrara un mensaje de error si se introducia una cantidad en un formato incorrecto, pero no llega a ejecutarse dicho codigo
No estoy muy seguro de lo que voy a decir pero pienso que la validación del formato del campo se hace antes de llegar al evento OnExit, de manera que podrías agregar el campo como persitente y usar su evento OnValidate.

// Saludos
Responder Con Cita
  #6  
Antiguo 28-04-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Es que el evento OnValidate se disparará solamente si el usuario ha introducido un valor que si es un número de coma flotante, pues el OnValidate no se encarga de "validar" cuestiones sintácticas.

Pienso que en el Evento OnSetText podrias capturar el error... pero hay que probar.

Bastará algo como:

Código Delphi [-]
Procedure Table1Campo1SetText(sender : TField; const Text: string);

Begin
  try
    sender.Value := StrToFloat(Text);
  except
    on EConvertError do
    Begin
      ShowMessage('Valor inválido!');
    End;
  end;
End;

hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
Respuesta



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


La franja horaria es GMT +2. Ahora son las 21:12:37.


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