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

Вниз

Отменть запрос во время его выполнения.   Найти похожие ветки 

 
Andrey V. ©   (2003-11-25 13:52) [0]

Как бы сделать сабжевую штуку ?
Типа вывесить окно с кнопкой "отменить" и слово "Ждите..." .
И по нажатию кнопки отменить выполнение запроса.


 
Карелин Артем ©   (2003-11-25 13:59) [1]

Обирясали мы как-то этот вопрос. В общем случае нельзя. Можно перестать фетчить записи.


 
Zacho ©   (2003-11-25 13:59) [2]

Единственный правильный способ:
1.Создаем генератор.
2. Создаем ХП с выборкой FOR SELECT, внутри цикла FOR SELECT проверяем значение этого генератора, если оно равно чему-то определенному (например, 1) - то exit
3. Запускаем запрос SELECT * FROM SP в отдельном потоке, и естественно в отдельном коннекте и отдельной транзакции.
4. В основном потоке делаем окошко с кнопкой "отменить", по нажатию этой кнопки устанавливаем значение генератора.


 
Digitman ©   (2003-11-25 14:01) [3]

оформляй исполнение запроса в ХП, возвращающей НД с пом. курсора :
FOR
SELECT ..
FROM ..
WHERE ((... ) AND (GEN_ID(GEN_ABORT, 0)= 0)
INTO ...
DO
SUSPEND;

по нажатию на кнопку стартуешь док.тред, в котором создаешь отдельный коннект к той же базе и инкрементируешь генератор GEN_ABORT

с этого момента условие GEN_ID(GEN_ABORT, 0)= 0 выполнено не будет, курсор будет уничтожен, ХП завершится, тем самым выполнение запроса будет корректно прервано


 
Andrey V. ©   (2003-11-25 14:20) [4]

Мда. Довольно геморрно. Спасибо.


 
Johnmen ©   (2003-11-25 15:24) [5]

Да можно просто в простом запросе это добавить. И указать эту проверку первой в where. ХП вовсе не нужна...
А с ХП уж лучше, в смысле, быстрее, просто делать проверку знач.генератора (не в запросе, но в цикле), и отваливаться...



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

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

Наверх




Память: 0.48 MB
Время: 0.022 c
1-52263
Yurko
2003-12-05 15:40
2003.12.16
Работа с MS-WORD


3-52060
Leo_
2003-11-23 05:16
2003.12.16
Самоадресуемые записи - как с ними работать?


14-52374
Дон Хуан
2003-11-03 12:42
2003.12.16
---|Ветка была без названия|---


1-52187
timak
2003-12-02 20:43
2003.12.16
КАК перевернуть QRLabel?


3-52106
Vanek
2003-11-24 10:30
2003.12.16
По интерфейсу