Ejecuta tu StoredProc en un Hilo y sincroniza los datos usando Shyncronize() yo lo uso siempre para la gestion de reportes que normalmente son tardados tambien lanzo una ventanita con un cargador (gauge) para que el usuario sepa que la consulta se sigue ejecutando, mientras tanto puedo seguir interactuando con el programa.
|