![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
ayuda con el evento OnValidate!!
Hola amigos, voy a resumir lo mas que pueda el problema q tengo y quisierea que por favor me ayudaran :
tengo un DBGrid asociado a Table1, y un boton en el evento OnClick del boton tengo esto: Table1.Append; Table1.FieldByName('codigo').AsString := '005'; Table1.Post; **************************** en el evento OnValidate del campo 'codigo' tengo esto: Showmessage(Sender.Text); Abort; **************************** tengo registros cuyos valores en 'codigo' son 001,002,003 y 004; mi problema es q cuando hago click en el boton, el DBGrid o mejor dicho el Dataset repite todos los valores contenidos en el campo 'codigo' a 005 , en vez que solo se afecte al nuevo registro que estoy ingresando. Muchas Gracias!!! ![]() |
#2
|
|||
|
|||
Probá con Insert en vez de Append.
Si el campo codigo se ordena automáticamente, el nuevo dato 005 debería ponerse último. Probalo y después comentá si te sirvió. Saludos! |
#3
|
|||
|
|||
probe con insert y me sigue causando ese problema
Cita:
probe con insert y me sigue causando ese problema |
#4
|
||||
|
||||
Cita:
// Saludos |
#5
|
|||
|
|||
Cita:
es que lo quiero a grandes rasgos es mostrar un mensaje advirtiendo que no existe el codigo que se esta ingresando en mi tabla1, abortando luego la grabacion de dicho registro, en este caso el codigo 005 no existe , los codigos los jalo de otra tabla (tabla2) y esta tabla solo tinene los codigos 001,002,003 y 004 OnValidate del campo 'codigo' de tabla1 if not tabla2.locate('codigo', '005', []) then begin Showmessage('el codigo no existe'); Abort; end; previamnete mi tabla 1 ya tiene 4 registros bien validados q son el 001,002,003 y 004 cuando intento ingresar el 005 la columna que representa al campo 'codigo' de la tabla 1 muestra en todas sus filas el valor 005 cuando aparece le mensaje pero se restablecen cuando pulso Ok en el mensaje Gracias por responder y porsupuesto por la ayuda |
#6
|
||||
|
||||
El problema tiene que ver con la forma en que trabajan los métodos SetData, Validate y GetData de la clase base nativa TField.
Primero, el método SetData establece en el campo (variable) FValueBuffer el valor que está por ser asignado al campo:
Luego el método SetFieldData del conjunto de datos (sea BDE, ADO, etc.), llama al método Validate del campo:
El método TField.Validate es quien se encarga de llamar al evento OnValidate, estableciendo temporalmente una bandera, FValidating, en True:
Dicha bandera tiene efecto en la forma en que trabaja el método TField.GetData, el cual se ejecuta siempre que algo requiere leer el valor del campo.
Como puede verse, cuando no se está ejecutando el método Validate (FValidating es False), el valor del campo es obtenido a través del método GetFieldData del conjunto de datos, el cual traerá el valor real del campo que corresponda a la fila actual. Pero si la bandera FValidating es True, el valor NO será leído del registro actual, sino del buffer FValueBuffer establecido desde que se llamó a TField.SetData (cuando la captura del dato fue recién ingresada). El problema con este mecanismo ya tan antiguo de la VCL es que si, durante la ejecución del evento OnValidate, algo necesita leer el valor del campo en cuestión pero de diferentes filas —tal como ocurre siempre en un control TDBGrid cuando éste se despliega—, se estará leyendo y dibujando en pantalla el mismo valor para todos los registros. Cuando la validación termina, el método Validate vuelve a poner la bandera FValidating en False, permitiendo que, la siguiente vez que la rejilla se dibuje, el método GetData lea el valor del registro real y ya no del buffer temporal FValueBuffer. Saludos. Al González. ![]() Última edición por Al González fecha: 22-03-2010 a las 04:09:50. |
#7
|
||||
|
||||
Interesante Al. Como dices, no es recomendable recorrer el dataset en uno de sus eventos. Como no da mayores detalles no se me ocurrió que quizá tuviera enlazadas ambas tablas. De hecho, me uno a la invitación de exponer más claramente el código y el contexto. De entrada, la condición
no parece ser correcta, lo que me sugiere que no nos está poniendo el código realmente usado. // Saludos |
#8
|
|||
|
|||
![]() ***************************************
realmante es muy interesante lo q dices, es bueno saber el orden de los eventos como se disparan. Bueno; Basicamente hago refernecia a dos conjuntos de datos , una es una tabla donde almaceno mis productos representado por un ADOTable (tbArticulos) y el otro es una lista de precios para mis productos representado por un ADOQuery (qryListaPrecios), ademas tengo un formulario de busqueda de articulos como mensione antes tengo un DBGrid conectado a qryListaPrecios donde el campo1 almacena el item del registro, el campo2(id_articulo) es donde ingreso el codigo del articulo ya sea digitandolo o llamando al formulario de busqueda de articulos aqui les muestro el codigo real
cuando ingreso tecleando en el campo id_articulo (segunda columna de mi grilla) no hay problema, si digamos ingreso un articulo q ya esta registrado en la lista de precios aparece el mensaje advirtiendome q ya existe en la lista de precios actual y luego aborta la oparacion sin problemas el problema es es cuando presiono F1 para llamar a mi formulario de busqueda y selecciono un articulo que ya esta ingresado en la lista de precios, al momento de aparecer el mensaje es donde se repite en valor del articulo validado en todas las filas, pense que se trataria de formulario de busqueda o d mi query pero me di cuenta que resumiendolo hasta lo mas sencillo causa ese problema con BDE, ADO tabla y/o consulta aunque pasando la logica al evento Onchange y BeforePost, resulta bien, pero me gustaria saber si se puede gestionar las validaciones en OnValidate Muchas Gracias denuevo!!!! Última edición por _CALI fecha: 17-03-2010 a las 13:58:47. Razón: editar sintaxis delphi |
#9
|
||||
|
||||
Hola de nuevo _Cali.
![]() Por favor usa las etiquetas Delphi para que tu código no pierda el sangrado y pueda leerse con mucho mayor facilidad. Esto lo puedes hacer fácilmente editando tu último mensaje, seleccionando todo lo que es código y oprimiendo el pequeño botón que parece un partenón en miniatura, a la izquierda del botón SQL ("Resaltar sintaxis Delphi"). Gracias. |
#10
|
|||
|
|||
![]() Cita:
Ok, ya esta con las estiquetas obviamnete se ve mucho mejor, Al Gonzales, espero puedas ayudarme con esto |
![]() |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
onvalidate | lejia | Varios | 12 | 12-10-2007 22:08:49 |
como validar en el evento onvalidate con numeros... | uper | Varios | 1 | 25-10-2005 20:06:49 |
OnValidate | javiermorales | OOP | 5 | 13-11-2003 15:52:52 |
ayuda sobre evento en php | jfvoviedo | PHP | 2 | 22-08-2003 16:12:04 |
ayuda sobre evento en php | jfvoviedo | PHP | 6 | 26-07-2003 18:24:22 |
![]() |
|