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

Вниз

Прогресс выборки TADOQuery нерегулярный   Найти похожие ветки 

 
Tack   (2008-01-30 11:45) [0]

Делаю выборку всех записей из таблицы MS Access. Использую TADOQuery (Ms Jet) с флагом ExecuteOptions = eoAsyncFetchNonBlocking
Для отображения асинхронного прогресса выборки у TADOQuery есть событие OnFetchProgress, которому передаются Progress, MaxProgress (Integer), кол-во записей соответственно прочитанных и оставшихся.

Попытка отображения прогресса на градуснике по этим параметрам приводит к тому, что прогресс очень быстро доходит до 99% и ждет завершения выборки, не особо двигаясь вперед, т.к. по ходу выборки Progress и MaxProgress уравниваются.

Что сделать, чтобы выборка отображалась на индикаторе более регулярно?


 
sniknik ©   (2008-01-30 11:57) [1]

поменять флаг... eoAsyncFetchNonBlocking на чтото другое... не помню, но точно не на неблокирующий (скорее на просто асинхронный).
и еще чтото, по мелочи, надо посмотреть. но главное надо "убить" TADOQuery и заменить его TADODataSet-ом.


 
sniknik ©   (2008-01-30 12:10) [2]

хотя нет, сорри, с eoAsyncFetchNonBlocking тоже работает, дело в другом.

а вот то, что MaxProgress содержит общее количество это не верно, в нем количество обработанных на данный момент, в Progress количество переданных на клиента...
т.что чтобы узнать общее надо предварительно запрос на количество делать, и молиться чтобы оно не изменилось в процессе. ;о)


 
DiamondShark ©   (2008-01-30 12:17) [3]

Редко какой провайдер сообщает точное значение счётчика строк для результирующего набора.

Остаётся только смириться.


 
ANB ©   (2008-01-30 12:46) [4]


> Tack   (30.01.08 11:45)

Прогресс отбора имеет смысл только для отображения процесса фетча большого количества записей как результата очень простого запроса.
Типа селект * фром Табле1.
Однако такие запросы не есть хорошо, а иногда могут просто завалить сервер.
В других же случаях, как правило, большая часть времени уходит на обработку запроса, а не на передачу строк на клиента. И в этих случаях прогресс бессмысленен.


 
Tack   (2008-01-30 13:01) [5]

ну что ж, тогда сделаю просто какую-нибудь крутилку "занятости системы", типа песочных часов.
Всем спасибо.



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

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

Наверх




Память: 0.47 MB
Время: 0.012 c
9-1171566617
vlk32
2007-02-15 22:10
2008.07.06
Есть желающие принять участие в разработке игры?


2-1213083727
vint45
2008-06-10 11:42
2008.07.06
Количество потоков на один процесс


2-1212666969
Mark86rus
2008-06-05 15:56
2008.07.06
Запуск DOS-Winrar со стройкой


15-1211345382
HHNick
2008-05-21 08:49
2008.07.06
Спящий режим


15-1211732282
No_Dead
2008-05-25 20:18
2008.07.06
Вопрос о include и рекламе