Главная страница
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.017 c
9-1171566617
vlk32
2007-02-15 22:10
2008.07.06
Есть желающие принять участие в разработке игры?


11-1189512903
SergeR
2007-09-11 16:15
2008.07.06
Вопрос по KOLmdvShellControls


2-1212846624
WebSQLNeederrr
2008-06-07 17:50
2008.07.06
Как узнать следующее вхождение pos-a


2-1212966315
Res
2008-06-09 03:05
2008.07.06
потоки


2-1212753107
opoloXAI
2008-06-06 15:51
2008.07.06
FileExists(myfName)