FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Añadiendo otra opcion a las del amigo Roman, Si trabajas en una BD Paradox podrias activar la casilla RequiredField, asi el mismo BDE se encargara de la validacion
__________________
...Yo naci en esta ribera del arauca vibr@d0r Soy hermano de la espuma, de la garza, de la rosa y del sol... Viva Venezuela |
#2
|
|||
|
|||
puedes poner un código parecido al siguiente en el evento BeforePost del dataset con el que trabajas
Código:
for i:=0 to Dataset.FieldCount-1 do if (Dataset.Fields[i].Required) and (Dataset.Fields[i].asstring='') then begin Showmessage('Faltan datos para completar el registro:'+Dataset.Fields[i].Fullname ); Abort; exit; end; |
#3
|
||||
|
||||
Los campos (TField) y sus descendientes tienen el evento OnValidate, que sirve precisamente para realizar validaciones a nivel de campo. Si el valor no es aceptable, simplemente elevas una excepción y ese valor bajo ninguna circunstancia llegará a la base de datos.
Por otro lado hay que recordar que poner required a True previene que el campo sea Null, pero no previene que contenga una cadena vacia. Si esto es aceptable o no, dependerá de tus especificaciones, y el comportamiento final dependerá del motor de base de datos, por ejemplo, para interbase/firebird (siguiendo el estándar SQL) '' <> NULL, pero para el desobediente oracle (al menos hasta la versón 9i, no he probado la 10g) '' = NULL Por último, si tu registro completo necesita validaciones mas complejas (la validez del valor de un campo depende de el valor de otro, por ejemplo) es mas facil, como te aconsejó ya Julià, utilizar el evento BeforePost. Como buena práctica, en lugar de mostrar el mensaje y luego lanzar la excpción con Abort, yo elevo una excepción con el dato en su miembro message (y quizas de una clase especializada), y dejo que la decisión de si debe o no mostrarse un mensaje (y cual) quede por otro lado... Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#4
|
|||
|
|||
Gracias a todos,
Gracias Julia, el codigo me funciono a la perfeccion. atte . Utecyber. Por cierto estoy en un nivel Medio todavia.. Gracias.. |
|
|
|