Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 19-02-2004
Eolo Eolo is offline
Miembro
 
Registrado: jun 2003
Ubicación: Lanus-Buenos Aires-Argentina
Posts: 29
Poder: 0
Eolo Va por buen camino
Unhappy Dar tiempo de respuesta a una consulta

Hola, como estan
Esta vez los molesto para preguntar si alguien sabe como hacer para que una consulta que hago con un Tquery a una base interbase tenga un tiempo maximo de respuesta y que si no trae el resultado en ese tiempo pueda mostrar un mensaje como que exedio el tiempo maximo de espera.
Y ya que estamos pregunto como hago para poner un tiempo maximo de conexion a la base de datos con el componente tdatabase.
ACLARACION: Estoy utilizando los componenetes del Data Access y no los de InterBase en donde usaria la propiedad idle timer

Desde ya muchas gracias
Responder Con Cita
  #2  
Antiguo 19-02-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Se me ocurre lo siguiente:
var
lFinal:Boolean;

lFinal:=False;
//antes de empezar la consulta lanzar un Timer
al Acabar la consulta
lFinal:=True;

Si el evento del Timer lo ponemos al tiempo máximo de espera;
entonces:
if lFinal = False then.....

A ver si te puede servir la idea.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 19-02-2004
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 25
__cadetill Va por buen camino
Hola Marcos

Sin haberlo probado, yo diría que eso no va a funcionar, más que nada porque a la que haces un Open en la Query, el programa queda congelado hasta que el servidor devuelve el resultado de la consulta, por lo que no creo que saltara el OnTimer del TTimer (bueno, saltaría pero después de que el servidor devolviera el resultado y se procesasen los mensajes)

Una opción que sí funcionaría, sería lanzar el SQL en un hilo de ejecución (Thread) aparte del principal y, esta vez sí, controlar con un TTimer el tiempo y, si supera el tiempo deseado, matar el hilo. Claro, no se como reaccionaría el servidor al matar ese hilo ¿quedaría la consulta pillada en el servidor? Supoongo que dependerá del servidor que haya detrás de la consulta
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 19:50:31.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi