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

Вниз

Дисконнект?   Найти похожие ветки 

 
RavenD   (2004-09-21 18:24) [0]

Привет, All!

народ, подскажите как правильно отлавливать дисконнект с сервером (MSSQL, ORACLE), пользуюсь связкой TDataBase -> TQuery(TTable)

Спасибо.


 
Vlad ©   (2004-09-21 18:33) [1]


> RavenD   (21.09.04 18:24)  

Есть событие у TDataBase - Before/AfterDisconnect
Правда если враги перережут сетевой провод - это не поможет.


 
RavenD   (2004-09-22 09:10) [2]

>Vlad
а если как раз случится страшное "враги перережут сетевой провод" что ещё можно предпринять?


 
Johnmen ©   (2004-09-22 09:12) [3]

А ты хочешь сразу это обнаружить или при выполнении очередного запроса ?


 
Sergey13 ©   (2004-09-22 09:14) [4]

2[2] RavenD   (22.09.04 09:10)
>а если как раз случится страшное "враги перережут сетевой провод" что ещё можно предпринять?
1. Радио связь - резать нечего.
2. Харакири.


 
RavenD   (2004-09-22 09:19) [5]

> Johnmen

требуется коректно завершить всю работу, закрыть все открытые источники, и хотелось сделать это как то централизованно, без навешивания на каждый TTable, TQuery

> Sergey13
не надо глумится, если есть что сказать по существу обязательно выслушаю, а спамить не надо, пожалуста


 
KSergey ©   (2004-09-22 09:28) [6]

> [5] RavenD   (22.09.04 09:19)
> требуется коректно завершить всю работу, закрыть все открытые
> источники


С обрезанным-то проводом??? И после этого еще можно не глумиться? ;)


 
Sergey13 ©   (2004-09-22 09:34) [7]

2[5] RavenD   (22.09.04 09:19)
>не надо глумится, если есть что сказать по существу обязательно выслушаю, а спамить не надо, пожалуста
Ну во первых не спамить а флудить. 8-)
Во вторых я предложил конкретный выход от пореза - радио.
В третьих - это ты глумишься, требуя при обрезании кабеля корректного завершения сетевого приложения.


 
Johnmen ©   (2004-09-22 09:34) [8]

Тогда общий подход примерно такой.
1. Каждое действие (последовательность действий), приводящее к посылке запроса на сервер, заворачивается в try.
2. В except указанного try выставляем нашу глобальную переменную (напр. Connected) в False. Изначально она True.
3. Имеем таймер, в котором анализируем Connected. И если облом, то предпринимаем необходимые действия. Видимо, закрываем коннект.


 
Мышь   (2004-09-23 18:10) [9]

А зачем "закрывать все открытые источники"? Само все будет. На халяву, при разрушении соответствующих компонентов.



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

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

Наверх




Память: 0.48 MB
Время: 0.024 c
1-1097558631
Брат
2004-10-12 09:23
2004.10.24
Установка формата даты


14-1096901158
kaZaNoVa
2004-10-04 18:45
2004.10.24
API & VCL быстрее, проще, лучше !


9-1087820889
Zak3D[@Tm]
2004-06-21 16:28
2004.10.24
OpenGL на Делфи и на С.


4-1095524688
Hensin
2004-09-18 20:24
2004.10.24
Отследить перетаскивание формы


1-1097344894
Ricks
2004-10-09 22:01
2004.10.24
Математика + Height Map