PDA

Ver la Versión Completa : Ejecución de query sin congelamiento


fryguy
19-07-2005, 22:42:59
Cuando ejecuto alguna consulta que tarda demasiado la aplicación se congela y no me devuelve el control hasta que termina.
Me refiero en particular a ejecuciónes de querys en los cuales no es necesario que me devuelva valores como por ejemplo una store procedure y se ejecuta con ExecSQL en vez de con Open.
Por ejemplo:

ADOQuery.SQL.Text := 'spAlgo @param1 = 8';
ADOQuery.ExecSQL;

¿como puedo hacer para ejecutar sin que la aplicación se congele?

Gracias por adelantado.

delphi.com.ar
19-07-2005, 23:08:46
Nunca lo he probado en Delphi, pero he visto que los TAdoQuerys tienen una "ExecuteOption" llamada eoAsyncExecute.
Esto tendría que producir que las consultas se ejecuten en forma asincrónica!

Saludos!

Neftali [Germán.Estévez]
20-07-2005, 09:20:58
Otra opcion (que tampoco he probado) es utilizar Threads para ejecutar consultas o abrir tablas (también deberá funcionar en éste caso). Hay un artículo de MArcelo torres en:
http://www.delphi3000.com/articles/article_1503.asp?SK=
Te puedes registrar de forma gratuíta para acceder al artículo titulado:
"Opening Tables/Queries in Threads"

Si no deseas hacerlo o no tienes tiempo puedes acceder al mismo código en:
http://www.delphibyte.com/article/viewart.php?id=187

NOTA: Tal vez te ayude para leerlo ir a ésta dirección:
http://babelfish.altavista.com/
donde pone "Translate a Web page" escribir la anterior y seleccionar como idiomas: Chinesse-simpl to English

fryguy
20-07-2005, 15:08:58
Ahora voy a probar con las direcciones que me pasó Neftalí pero mientras tanto les cuento que he intentado usar el eoAsyncExecute y que el estado no cambia cuando uso el ExecSQL (si cuando uso el Open) entonces no encontré la forma de controlar la ejecución asíncrona.
En una de esas hice algo mal en las pruebas y por eso no funcionaba, como ya me ha pasado otras veces no lo descarto del todo.

La idea de ejecutar las consultas con un thread es buena, se me había pasado por la cabeza pero quería verificar con los expertos alguna idea más simple.

Gracias por todo y si a alguno se le ocurre algo más no me voy a negar a escuchar ;D.