Ver Mensaje Individual
  #1  
Antiguo 25-06-2025
emeceuy emeceuy is offline
Miembro
 
Registrado: jun 2003
Ubicación: Uruguay
Posts: 128
Reputación: 24
emeceuy Va por buen camino
evento CALCFIELDS largo rompe datos en dbgrid

Hola buen dia !

Tengo una aplicacion bastante vieja a la que necesito hacer una modificacion.

La aplicacion usa un TQuery con BDE y tablas DBF (si, ya se, es viejo), cuya informacion muestra en un TDBGid. Ese Query tiene campos calculados, ya que mucha de la informacion guardada en la base de datos es un codigo y no necesito mostrar el codigo y la descripcion. Por ejemplo, guardo el PROVEEDOR codigo 11, pero en la grilla quiero mostrar "11 - PROVEEDOR X". Para eso hago una consulta a la tabla de proveedores y busco el nombre, y asi armo el campo calculado.

El problema es que en el procedimiento OnCalcFields del Query tiene varias de esas consultas a otras tablas, y lo hace "lento".

A los efectos del usuario, ni lo nota. Si me desplazo en la grilla usando la barra de desplazamiento, o el scroll, o mismo las flechas arriba y abajo (y la presiono registro a registro, levantandola), no hay problema. Pero el error sucede cuando dejas presionado la tecla de la flecha de arriba o abajo y se desplaza rapidamente. Ahi los registros que por ejemplo estaban arriba y no se veian, cuando los muestra, no los muestra bien (los entrevera con otros registros). Si me desplazo dentro de los registros que muestra (o que entran) en la grilla, no hay problema. El problema surge cuando tiene que mostrar los que no se ven y estan arriba o abajo, y dejo presionada la tecla de arriba o abajo.

No se si se entiende, es mas dificil de explicar el problema de lo que realmente es. Mi sospecha es que como el evento oncalcfields tiene consultas a otras tablas, se hace demorado, y ahi se le entreveran los registros al delphi, porque cuando te desplazas "lentamente" no hay problema.

Se que una solucion seria hacer un gran query con join y ya traer la info de todas las tablas jutas, pero quisiera evitarlo para evitar pasar horas reconstruyendo y modificando todo.

Alguien tuvo este problema? Se les ocurre solucion?

Muchas gracias, saludos !

Marcelo
__________________
Marcelo C.
Responder Con Cita