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

Вниз

Сортировка по клику на заголовке   Найти похожие ветки 

 
Milashka ©   (2006-07-20 08:15) [0]

Уважаемые Мастера!

Сортировку по клику на заголовке таблицы осуществляю так:

procedure TFPerehod.DBGridEhPrihodTitleBtnClick(Sender: TObject;
 ACol: Integer; Column: TColumnEh);
begin
 if  column.Title.SortMarker=smDownEh
then
 column.Title.SortMarker:=smUpEh
else
  column.Title.SortMarker:=smDownEh;

 Perehods.MakeOrder(Column.FieldName,column.Title.SortMarker);

end;


procedure TMy_DataSets.MakeOrder(FieldName:string;SortMarker:TSortMArkerEh);
begin
OrderSQL.Text:=" order by "+FieldName;
 if SortMarker=smUpEh
  then
    OrderSQL.Text:=OrderSQL.Text+" desc ";

ActivateDataSet();

end;


проблема в том, что в запросе датасета используются псевдонимы для
столюбцов таблиц, а сортировку по ним делать не получается (InterBase).
т.е. в запросе например:
select
  perehod.idperehod, perehod_status.naimenovan  as statname,
....
 
надо написать

order by perehod_status.naimenovan ,
но в таблице FieldName идет statname.

Подскажите пожалуйста, как выйти из данной ситуации.
Может в DBGridEh в столбце хранить полное имя поля (perehod_status.naimenovan), вот только где???


 
clickmaker ©   (2006-07-20 11:54) [1]

TField.Origin


 
ORMADA ©   (2006-07-20 12:11) [2]

кстати в Ehlib 4.x это делается с помощью встроенной мемори таблы автоматом при наличии DataService
под ИБ там есть....
кстати многи чего ещё нового по сравнению с 3.х



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

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

Наверх




Память: 0.47 MB
Время: 0.029 c
2-1153168935
GanibalLector
2006-07-18 00:42
2006.08.06
OLE Automation


3-1149162724
Dust
2006-06-01 15:52
2006.08.06
опятьBlob, перекачка инфы с помощью стримов


2-1153131002
Квэнди
2006-07-17 14:10
2006.08.06
Преобразование даты в Posix формат


2-1153455791
PSPF2003
2006-07-21 08:23
2006.08.06
TSearchRec в Инете


2-1151795588
SUN_ALF
2006-07-02 03:13
2006.08.06
Перехват и остановка только что запущенного процесса