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

Вниз

Как отменить выполнение SQL-запроса (SELECT) во время выполнения?   Найти похожие ветки 

 
Nikolai_S ©   (2002-07-31 15:29) [0]

Вопрос к знатокам ADO:
Как сделать так, чтобы во время выполнения запроса на выборку большого объема данных в ProgressBar отображался % выполнения запроса, а сам запрос можно было в любой момент отменить?

У TADODataSet существует свойство ExecuteOptions, где можно установить eoAsyncExecute и eoAsyncFetch. Тогда выполнение происходит в отдельном потоке. Однако это не помогает, так как нельзя отменить выполнение запроса и в событии OnFetchProgress процент указывается неравномерно.


 
wicked ©   (2002-07-31 16:55) [1]

отменить - метод cancel.....


 
Fiend ©   (2002-07-31 17:32) [2]

Отменить можно методом cancel, как сказали выше, но тогда надо выполнять запрос с TADOCommand, у него есть этот метод.


 
Nikolai_S ©   (2002-08-01 09:54) [3]

Согласен, что если выполнять через TADOCommand, то есть метод Cancel, который отменит выполение запроса. Но как отловить процент выполнения запроса? У TADOCommand нет событий. Даже если выполнять через TADOTable или TADOQuery, то там есть событие OnFetchProgress - однако с помощью этого события нельзя вывести процент выполнения запроса. У события есть параметры Progress, MaxProgress. Но MaxProgress почему-то тоже меняется вместе с Progress. И получается, что сначала львиную долю времени горит 0 %, а когда запрос почти выполнен, то горит около 80% - а потом сразу 100%.


 
Johnmen ©   (2002-08-01 09:59) [4]

Достоверный процент прогресса - вешь нереализуемая в принципе !


 
Nikolai_S ©   (2002-08-01 15:17) [5]

Чем это объяснить? Я видел какие-то компоненты (хотя я их не устанавливал и не смотрел как они работают), которые как раз такую возможность предлагали.


 
SaS13 ©   (2002-08-01 16:04) [6]


> Я видел какие-то компоненты

Было бы интересно на них, а лучше ни их исходники, посмотреть.
Может кинешь ссылочку



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

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

Наверх




Память: 0.48 MB
Время: 0.012 c
1-71183
big_bugzy
2002-08-09 16:33
2002.08.22
Вопрос по MDI формам


1-71125
maxim2
2002-08-13 10:05
2002.08.22
Можно ли отловить двойной клик правой клавиши мыши на элементе


14-71366
Eugene_Jek_Efimochkin
2002-07-10 00:25
2002.08.22
Где взять контролы, похожие на XP?


1-71177
cult
2002-08-09 16:15
2002.08.22
Как сделать форму Always-on-top?


6-71291
return
2002-06-11 18:29
2002.08.22
Загрузить в Memo1 текст содержания файла http://test.ru/test.html