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

Вниз

Отмена запроса, но как ???   Найти похожие ветки 

 
inic   (2004-06-07 13:58) [0]

Мое почтение!!!
Есть такой документ:
"Interbase, Firebird, Yaffil FAQ"
(http://www.ibase.ru/v6/ib6faq.htm).
И там сказано:
"...
Теперь на второй вопрос - новое в 6.5:
  Возможность снятия долгих запросов (из параллельного
  thread)через IB API
...".
Очень хотелось бы узнать, как это сделать ?
Заранее спасибо.


 
Digitman ©   (2004-06-07 14:35) [1]

создается отдельный генератор, например, MyGen

некий код.поток A кл.приложения перед запуском длит.запроса сбрасывает этот генератор в исх.состояние, например,  = 0

далее этот же код.поток A вызывает на выполнение некий длит.запрос, в котором кроме прочих WHERE-условий отбора записей фигурирует доп.условие GEN_ID(MyGen, 0) = 0

пока значение ген-ра MyGen равно 0, условие выполняется и запрос продолжает исполняться

одним из ключ.условий прекращения выполнения запроса в этом случае будет НЕвыполнение условия GEN_ID(MyGen, 0) = 0, чего можно достичь, например, инкрементом значения генератора

поскольку код.поток А кл.приложения блокирован в этот момент ожиданием результатов выполнения запроса, он не может инкрементировать генератор MyGen с целью обеспечения ложности упомянутого условия

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

при этом как только выполняющийся длит.запрос обнаружит невыполнение условия GEN_ID(MyGen, 0) = 0, он немедленно прекратит исполнение


 
inic   (2004-06-07 15:23) [2]

Была у меня идея отделенно похожая (там даже UDF фигурировали),
но этот способ конечно и лучше, и проще.
Огромное спасибо.

P.S.
Но все таки интересно, что они имеют в виду. Я думаю что-нибудь
типа gds32.dll::gds_query_cancel(...). Кстати, в Yaffil такая отменяющая штука вроде тоже есть.


 
Digitman ©   (2004-06-07 15:25) [3]


> интересно, что они имеют в виду


если подразумевать уровень совместимости IB и его клонов, то именно трюк с генератором и имелся ввиду


 
Alexandr   (2004-06-08 10:11) [4]

там же написано
"новое в IB6.5"
вот только запрос если срубить через IB API таким способом, то это с некоторой отличной от нуля вероятностью может привести в той или иной степени к порче базы данных.



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

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

Наверх




Память: 0.47 MB
Время: 0.027 c
14-1087016392
Думкин
2004-06-12 08:59
2004.07.04
С днем рождения! 12 мая.


4-1085408066
SMART_n
2004-05-24 18:14
2004.07.04
Проблемы с I/O completion port


14-1087154461
Diver
2004-06-13 23:21
2004.07.04
Головоломка про сломанные ноги


9-1079030091
010101001010001010101001
2004-03-11 21:34
2004.07.04
АРКАНОЙД


14-1086934866
Digitman
2004-06-11 10:21
2004.07.04
И смех и грех ..