Поиск:

Ответ в темуСоздание новой темы Создание опроса
> FetchAll в FIBDataSet и сортировка 
:(
    Опции темы
Zmitro
Дата 28.7.2008, 14:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 32
Регистрация: 19.3.2008

Репутация: 1
Всего: 1



Доброго времени суток всем!
При опции в 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 последних записей и при этом чтобы еще и сортировалось.
PM MAIL   Вверх
Vas
Дата 28.7.2008, 14:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



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

Запросом 
Код

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



--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
Zmitro
Дата 28.7.2008, 14:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 32
Регистрация: 19.3.2008

Репутация: 1
Всего: 1



при 
Код

select * from table
order by [нужное поле] 
 и при poFetchAll=False клиент получит количество записей, указанных в BufferChunks, а если в BufferChunks < чем кол-во записей в таблице/запросе тогда сортировка не едет
PM MAIL   Вверх
Vas
Дата 28.7.2008, 15:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



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

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

Это сообщение отредактировал(а) Vas - 28.7.2008, 15:40


--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
Akella
Дата 29.7.2008, 15:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Zmitro, сортировать только часть записей глупо, откуда гриду знать что и как сортировать, если он получил 10 записей из 20? Получается как? Пользователь пркручивая постепенно грид будет ТАКОЕ видеть smile , т.к. записи буду добавляться в грид и после добавления очередной записи будет происходить пересортировка так сказать? Или записи, которые будут добавляться в грид будут идти уже последними?
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0938 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.