![]() |
Como Refrescar un Query
Tengo 2 formularios, el primero contiene un DBGrid donde listo el resultado de un Query por Ej
Y en el segundo tengo un grupo de tEdit para actualizar los campos, para ello al crear el 2do from paso los parametros DatabaseName, TableName, CampoClave y ValorClave
Uso 2 TQuery en el segundo formulario uno lee el registro usando (SELECT * FROM TableName WHERE CampoClave = ValorClave) y el otro lo uso para actualizar con INSERT, UPDATE o DELETE. El Problema es que después de guardar los cambios y cerrar el 2do formulario (ModalResult = mrOK) lanzo un refresh sobre la tabla del DBGrid y no me aparecen las actualizaciones.
Pero si cierro el formulario (f.free) y lo vuelvo a abrir (f.create .. ShowModal) si aparecen los cambios. Tambien funciona con un q.Close; q.Open; en lugar del q.Refresh; pero me parece ilógico tener que cerrar y abrir una base de datos para refrescarla. Nota Por ahora trabajo sobre Paradox 7 con Delphi 7 pero la intención es poder usar otros motores de BdD. |
Pues aunque no te parezca lógico algunas bases de datos no tienes más remedio que abrir y cerrar para refrescarlas, pero no es el caso de Paradox, me da la impresión aunque no veo el código, que haces el refresco sobre la tabla, pero no cierras y abres la consulta que es la que te muestra los datos, con el refresh actualizas la tabla, pero la consulta no puesto que su datos son anteriores al refresco, prueba por ese lado y nos cuentas como te va.
Un Saludo. |
Quizá, aunque más bien es pregunta para Marcos, si el Query tiene su propiedad RequestLive en true, no haga falta cerrar y abrir la consulta.
// Saludos |
Hola...
Cita:
saludos... |
Hola Román, según creo RequesLive lo que permite es actualizar la consulta, es decir poder añadir un registro en una rejilla o modificar uno de los que se muestra, pero siempre y cuando no se hagan referencias a otras tablas y algún condicionante más, para ello tenemos la propiedad CanModify que es necesario consultar a pesar de tener RequestLive activado, pues no siempre se pueden actualizar o modificar las consultas.
De hecho cuando esto no es posible se utiliza el componente UpdateSql. Un Saludo. |
Gracias por responder (y tan rápido). El código que funciona quedo así:
|
Hola,
Ya hice algunas pruebas. Como dice Marcos, RequestLive tiene limitaciones, pero si la consulta asociada al DBGrid toma datos de una sola tabla (y algunas otras condiciones), puedes poner Query.RequestLive en true y al hacer Query.Refresh verás las actualizaciones de inmediato. Por otra parte, no sé si has considerado usar controles dbedit en el segundo formulario en lugar de edit normales. Si enlazas los dbedit del segundo formulario al mismo datasource del grid en el primer formulario, y tienes RequestLive en true, entonces ni siquiera necesitas el refresh, los cambios se ven atomáticamente. // Saludos |
La franja horaria es GMT +2. Ahora son las 06:18:34. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi