Главная страница
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.48 MB
Время: 0.02 c
15-1211534621
Slider007
2008-05-23 13:23
2008.07.06
С днем рождения ! 23 мая 2008 пятница


15-1211464998
Правильный_Вася
2008-05-22 18:03
2008.07.06
хитрое переименование файлов


2-1212792183
redlord
2008-06-07 02:43
2008.07.06
отображение каретки ввода в компоненте edit


8-1182078861
hahol
2007-06-17 15:14
2008.07.06
помогите разобраца в mci


4-1192513498
mx
2007-10-16 09:44
2008.07.06
Как отловить завершение работы Windows из под сервиса?