Форум: "Базы";
Текущий архив: 2002.08.22;
Скачать: [xml.tar.bz2];
ВнизКак отменить выполнение 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;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.008 c