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

Вниз

Как грамотно выполнить асинхронный ExecSQL в ODAC (Oracle)   Найти похожие ветки 

 
ANB ©   (2005-07-04 09:15) [0]

Сел перерабатывать свою прогу для асинхронного выполнения длительных запросов. Не очень хотелось бы уходить в отдельный поток, так как писать больше, проблемы с синхронизацией, плюс дублирование штатных средств. Нашел свойство NonBlocking. Если его включаешь, то запрос выполняеся асинхронно, можно ждать его окончания с помощью Executing и отменять запрос через BreakExec (все это на базе TOraQuery). Вылезла проблема - перестали генерится исключения в основном потоке, вместо этого стало выдаваться окно с ошибкой. Нашел в исходниках ODAC как это работает, перехватил Application.OnException, вроде работает, как надо.
Вопросы :
- правильно ли я все это сделал (нет ли способа красивее)
- как таким же образом переделать работу с TOraScript
Для TOraScript я попробовал подменить дейтасет на свой с включенным NonBlocking, но в результате получил только отключение исключений, а асинхронка все равно не работает.
Вижу 2 выхода - продолжать копаться в исходниках TOraScript или написать свою реализацию, тем более, что штатный ругается на некоторые скрипты, которые нормально выполняются в SQL Plus и TOAD (не любит пустые операторы из одних комментариев, не есть Exit)


 
ANB ©   (2005-07-04 11:26) [1]

Накопал проблему - Executing отрабатывает некорректно. То есть запрос еще работает, а он возвращает False;



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

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

Наверх




Память: 0.47 MB
Время: 0.037 c
6-1114271763
Galiaf
2005-04-23 19:56
2005.08.14
Где лежит компонент "TServerSocket" & "TClientSocket"?


1-1122357061
Sectey
2005-07-26 09:51
2005.08.14
Есть ли ключ компилятора


5-1092222402
far
2004-08-11 15:06
2005.08.14
Перехват изменения набора полей DataSet-а в design-time (2)


11-1104932501
Jon
2005-01-05 16:41
2005.08.14
MMTimer and Focus


1-1122372361
serjufa
2005-07-26 14:06
2005.08.14
ак программно из D5 заставить на листе Excel отобразиться сетке