Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.05.28;
Скачать: CL | DM;

Вниз

Как заставить recordset в ADO открывать запрос с таймаутом ?   Найти похожие ветки 

 
Rule ©   (2006-03-29 12:20) [0]

Ситуация такая, есть адошный рекордсет, у него есть метод OPEN типа такого
      FrecordSet.Open(FTableName, FConnection, RSCursor, RSLock, RSComandType);
Вопрос, если АДОдрайвер долго не отвечает (он же является драйвером железяки которая в виде таблиц возвращает данные), то эта фигня зависает намертво. Как сделать так, чтобы рекордсет пробовал открыться некоторое время, а потом продолжалось выполнение программы дальше ?
Спасибо всем за внимание ...


 
Rule ©   (2006-03-29 12:48) [1]

хорошо ещё пославлю вопрос под другим углом, у меня есьт переменная RecordSet:_Recordset;  как мне из другого потока во время выполнения команды FrecordSet.Open  прибить єто исполнение ?


 
Дырчик ©   (2006-03-31 05:58) [2]

TCustomADODataSet(TADODataSet).CommandTimeout := ...


 
sniknik ©   (2006-03-31 08:21) [3]

Дырчик ©   (31.03.06 05:58) [2]
зачем сложности с приведением? свойство достутно и в самом TADODataSet

> прибить єто исполнение ?
можеш попробовать сделать Close конекту.

лучше поставить таймаут (up), сам будет "прибиваться".

но вообще, если время критично, переходи на асинхронное выполнение и событийность... т.е. послал запрос прога сразу продолжила выполнятся. данные потребовались (прошло время) читаеш статус, если еще не выполнилось делаеш ему Cansel, ну и продолжаеш дальше, что там у тебя намечено.
и никаких задержек вообще.


 
Rule ©   (2006-04-03 13:17) [4]

sniknik ©   (31.03.06 8:21) [3]
зачем сложности с приведением? свойство достутно и в самом TADODataSet
а я работаю с рекордсетами а не датасетами ... и вобщем надо чтоб провайдер это поддерживал, а у мня не поддерживается ... это я знаю потомучто там по дефалту вроде стоит 30 секунд, а у меня может висеть до бесконечности


 
Rule ©   (2006-04-03 13:18) [5]

sniknik ©   (31.03.06 8:21) [3]
но вообще, если время критично, переходи на асинхронное выполнение и событийность... т.е. послал запрос прога сразу продолжила выполнятся. данные потребовались (прошло время) читаеш статус, если еще не выполнилось делаеш ему Cansel

Санцел виснет до конца выполнения опена, а если опен завис то и кенцел висит, правда при синхронном выполнении если задать команду из другого потока


 
Rule ©   (2006-04-03 13:19) [6]

sniknik ©   (31.03.06 8:21) [3]
а ассинхронное выполнение должно поддерживаться провайдером, или это заложено в самом механизме АДО ???



Страницы: 1 вся ветка

Текущий архив: 2006.05.28;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.063 c
2-1147560405
EZHIK
2006-05-14 02:46
2006.05.28
Разные действия для одной кнопки.


5-1132337922
CHES
2005-11-18 21:18
2006.05.28
Нестандартный элемент управления


2-1147078700
cardexc
2006-05-08 12:58
2006.05.28
не получается сделать запрос


2-1147152625
Неуч
2006-05-09 09:30
2006.05.28
ширина текстового поля в Tmemo


2-1147090942
AlexanderMS
2006-05-08 16:22
2006.05.28
Проблема с поиском.