FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Evitar mensajes de Error de Firebird
Hola
Tengo una barra de navegación hecha por mi en la cual manejo transacciones y cuando actualizao alguna tabla que tiene un campo requerido sin contenido me tira el siguiente mensaje: [code] Project miproyecto.exe raised exception class EDBEngineError with message. 'Field value requerided. validation error for column AGENCIA, value "***null***". Process stopped. Use Step o Run to continue ok help [code] Como puedo hacer para evitar esto ? Tengo bastante urgencia en solucionar este tema porque tuve que migrar hacia firebird una aplicación en una semana. Desde ya muchas gracias |
#2
|
||||
|
||||
Cita:
// Saludos |
#3
|
|||
|
|||
Hola no me explique bien
Lo que quise decir era lo siguiente:
Si defino un campo como requerido es obvio que tengo que ponerle un dato en el mismo para que no me de el error, pero sucede lo siguiente, en un formulario puedo tener n campos requeridos cada uno de ellos asociados a un componente dbaware, yo quiero que al presionar el boton de aceptar que es el que hace el post y el commit, antes del post poder chequear que todos los campos requeridos tengan un valor me explico ? por ejemplo for i:=0 to controlcount -1 do begin ????? como pregunto Controls[i]. ???? end; Saludos Y desde ya muchas gracias |
#4
|
||||
|
||||
¿Y cuál es la duda?
Si tienes un DBEdit asociado a un campo requerido basta que preguntes:
Si tienes varios DBEdit entonces haces lo mismo para cada uno de ellos. Si lo quieres hacer en un ciclo entonces el arreglo que debes recorrer no sería Controls sino el arreglo Fields del DataSet que uses:
pero de cualquier manera tienes que determinar en cada iteración si realmente es requerido el campo:
Nota sin embargo que un ciclo muy similar ya lo hace internamente el método Post y su forma de manejar el error es llamando a
que a su vez lanza la exepción con el mensaje que ya has visto. ¿Qué es entonces lo que necesitas? Porque yo veo en primera instancia sólo dos razones para repetir estas verificaciones:
ninguna de las cuales significa evitar el error. Ahora bien, cualqiera que sea la razón, realmente el lugar más adecuado para hacer tal verificación es en el evento OnBeforePost del DataSet. Verás, en términos generales, cuando llamas al método Post ocurren primeramente dos cosas:
CheckRequiredFields es quien realiza el ciclo sobre los campos del DataSet. Así que el evento OnBeforePost es el punto ideal, bien para proveer un valor faltante o bien para abortar el proceso (usando abort), ya que es independiente de como y cuando se llama al método Post. // Saludos |
#5
|
|||
|
|||
Campos requeridos
Hola, muchisimas gracias por tu respuesta.
Disculpa mi ignorancia, queria hacerlo en una clase para poder hacerlo sobre cualquier tabla que yo definiera en el formulario de la clase. Lo pruebo y te cuento Gracias por tu tiempo Saludos |
#6
|
|||
|
|||
Probando la solución:
en el onbeforepost
hice lo de Código:
for i:=0 to Dataset.fieldcount -1 do if Dataset.fields[i].requiered........ le puse el mensaje showmessage('el campo '+dataset.fields[i].name +' contiene un valor no válido') exit; Y despues del mensaje personalizado como hago para que la base no me tire igual el mensaje de error ????? Perdona mi ignorancia. Desde ya muchas gracias por tu respuesta Saludos Claudio |
#7
|
||||
|
||||
Cita:
Lo otro no se me ocurre nada ahora. A un mismo campo de un dataset puede haber conectados más de un control así que ¿cómo se podría determinar cual de todos los controles asociados al mismo campo fue donde se estaba editando? // Saludos |
#8
|
||||
|
||||
Cita:
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#9
|
||||
|
||||
Cita:
Cita:
// Saludos |
#10
|
|||
|
|||
Hola, gracias por responder
El tema que en un programa como el que estoy diseñando un campo va a estar asociado a un solo componente para que se ingrese su valor.
Desde ya muchas gracias por vuestro tiempo. Saludos Claudio |
#11
|
|||
|
|||
Código del Post en Delphi 3
Estuve revisando el código del Post y, en Delphi 3, primero se ejecuta el método CheckRequiredFields y recién luego OnBeforePost, lo cual no tiene sentido pero, en fin, es así.
La definición del método es la siguiente:
Última edición por ghuttemann fecha: 13-07-2007 a las 16:57:39. |
|
|
|