Главная страница
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.013 c
1-71227
Дима_Еп
2002-08-11 13:46
2002.08.22
Импорт/Експорт Excel


3-70971
TaiphooN
2002-08-04 12:54
2002.08.22
SQL с условиями


1-71171
Ярослав
2002-08-13 20:46
2002.08.22
Delphi & MySQL - это возможно?


14-71325
Romkin
2002-07-26 14:25
2002.08.22
Переход на MS SQL


1-71167
SashaK
2002-08-13 14:05
2002.08.22
Освобождение памяти