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

Вниз

как сортировать результаты запроса?   Найти похожие ветки 

 
AFrolov ©   (2002-09-30 11:24) [0]

Вопрос наверно уже встречался, но все же:
С помощью запроса получается набор данных, которые надо показывать пользователю по разному отсортированными (в зависимости от того по каким колонкам пользователь эту сортировку выбрал). Как можно изменить эту сортировку не выполняя повторно SQL - запрос (т.к. он длится довольно долго, а все необходимые данные были уже до этого получены). Может есть стандартные компоненты которые это делают?
Заранее спасибо.


 
3JIA9I CyKA ©   (2002-09-30 11:33) [1]

ExpressQuantumGrid


 
Desdechado ©   (2002-09-30 11:35) [2]

попробуй в StringGrid или ListBox (многоколоночный режим)


 
AFrolov ©   (2002-09-30 11:56) [3]


> 3JIA9I CyKA © (30.09.02 11:33)
> ExpressQuantumGrid

Клевый компонент, правда только за бабки и за приличные :-((


 
3JIA9I CyKA ©   (2002-09-30 12:21) [4]

Он их стоит.


 
AFrolov ©   (2002-09-30 12:22) [5]

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


 
3JIA9I CyKA ©   (2002-09-30 12:27) [6]

Получив данные - сложи их локально, и сортируй сколько угодно.
Я бы так сделал.


 
AFrolov ©   (2002-09-30 12:31) [7]

А с помощью чего это лучше сделать?


 
3JIA9I CyKA ©   (2002-09-30 12:34) [8]

Тут уже не совет нужен, а фантазия. Придумай кучу вариантов; исключи неприемлемые; выбери самый клёвый. 8)


 
AFrolov ©   (2002-09-30 12:39) [9]

Самое неприятное, что до меня это проделало уже много людей. Опять придется заниматься изобретением велосипеда. :-(.


 
Кулюкин Олег ©   (2002-09-30 12:49) [10]

2 AFrolov ©
1. Используйте TClientDataSet, он позволяет сортировать данные (в т.ч. по нескольким столбцам). Для отображения используйте RxDBGrid. Он умеет рисовать стрелки в заголокках.
2. Напишите свой класс, который будет хранить данные, и свой список этих классов. Отображать данные придется в ListView в виртуальном режиме.
Сортировать ручками (например доработанным методом QuickSort).


 
BlackTiger   (2002-09-30 14:20) [11]

Для бродящих по граблям или если надо быстро :-) :

Query1.Active := true; //можно опустить
Query1.Sort := "Field1 ASC, Field5 DESC";

Твоя задача - подставить название полей.
Либо используй EhLib (тут пролетала ссылка), там в примере все понятно.
Никакого обновления не происходит - сортируются только уже выбранные данные.


 
Prooksius ©   (2002-09-30 14:27) [12]

FIBPlus - там есть процедуры такие:

procedure Sort(DataSet: TFIBCustomDataSet; aFields: array of const; Ordering: array of Boolean);
procedure FastSort(DataSet: TFIBCustomDataSet; FieldNo: Integer; Ordering: Boolean);


сортируют без переоткрытия результаты уже открытого запроса.


 
3JIA9I CyKA ©   (2002-09-30 14:28) [13]

8)


 
AFrolov ©   (2002-09-30 14:37) [14]

Про то и вопрос был.

> BlackTiger (30.09.02 14:20)

Огромное спасибо.



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

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

Наверх




Память: 0.49 MB
Время: 0.024 c
1-68797
INCOGNITO
2002-10-09 22:33
2002.10.21
Копирование файла


1-68871
Palladin
2002-10-10 17:29
2002.10.21
Ужасный вопрос :)


14-68917
NeyroSpace
2002-10-01 11:07
2002.10.21
Open source проект


14-68993
Lola
2002-09-29 11:22
2002.10.21
Курица в пиве :)


7-69036
fishca
2002-08-14 15:18
2002.10.21
Архивирование