Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Delphi: Базы данных и репортинг > FetchAll в FIBDataSet и сортировка


Автор: Zmitro 28.7.2008, 14:17
Доброго времени суток всем!
При опции в FIBDataset poFetchAll=False и при подстановке в BufferChunks значения кол-ва строк >= реальному кол-ву строк в БД сортировка в Grid-е проходит без проблем. код для сортировки: 
Код

      begin
        DSAct.DoSort([Column.FieldName], [True]);
        Column.Title.SortMarker := smDownEh;
      end;

А если кол-во записей превышает значение BufferChunks сортировка не происходит.
Установка poFetchAll=True вызывает "...exeption class EListError with messages 'List index out of bounds (кол-во записей)'..." да и фитчить все  записи на стороне клиента в общем неправильно.
Вопрос: каким образом можно вытянуть на клиента к примеру 1000 последних записей и при этом чтобы еще и сортировалось.

Автор: Vas 28.7.2008, 14:27
Цитата(Zmitro @  28.7.2008,  14:17 Найти цитируемый пост)
Вопрос: каким образом можно вытянуть на клиента к примеру 1000 последних записей и при этом чтобы еще и сортировалось. 

Запросом 
Код

select * from table
order by [нужное поле] 

Автор: Zmitro 28.7.2008, 14:30
при 
Код

select * from table
order by [нужное поле] 
 и при poFetchAll=False клиент получит количество записей, указанных в BufferChunks, а если в BufferChunks < чем кол-во записей в таблице/запросе тогда сортировка не едет

Автор: Vas 28.7.2008, 15:38
При таком выборе запрос вернет значения уже отсортированные и серверу глубоко плевать на ваши fetchAll, почитайте про SQL много вопросов сами отпадут.

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

Автор: Akella 29.7.2008, 15:00
Zmitro, сортировать только часть записей глупо, откуда гриду знать что и как сортировать, если он получил 10 записей из 20? Получается как? Пользователь пркручивая постепенно грид будет ТАКОЕ видеть smile , т.к. записи буду добавляться в грид и после добавления очередной записи будет происходить пересортировка так сказать? Или записи, которые будут добавляться в грид будут идти уже последними?

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)