Поиск:

Ответ в темуСоздание новой темы Создание опроса
> DBAdvGrid + SimpleDataSet сортировка 
:(
    Опции темы
php5
Дата 8.2.2010, 18:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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




Через  SimpleDataSet подгружаю данные в  DBAdvGrid  нужно  теперь сделать возможность  локально  сортировки при клике по шапки  столбца .  Побывал  установить  свойство  DBAdvGrid1->SortSettings->Show = true  но это не помогло , хотя если  его установить в  true  для AdvStringGrid то  сортировка  работает нормально. 

PM MAIL   Вверх
vikaz
Дата 8.2.2010, 21:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Привет, камрад! А если попробовать это реализовать программно? Я такой цепочкой не пользовался (DBAdvGrid + SimpleDataSet), сам пользуюсь EhLib + UniDAC. Так вот, у компоненты EhLib, есть  свойство OnTitleClick. Функция имеет сл. параметры: TColumnEh *Column.
я у себя написал сл. код:
Код

void __fastcall TMain_Form::DBGridEh1TitleClick(TColumnEh *Column)
{
 UniQuery->SQL->Text = "select * from employee where EmployeeGroup=" + IntToStr (Active_Tab) + " order by " + Column->DisplayName;
 UniQuery->Open();
}
//---------------------------------------------------------------------------

Таким образом сортировка происходит по той колонке, по которой щелкнули ЛКМ. smile

Это сообщение отредактировал(а) vikaz - 8.2.2010, 21:45


--------------------
user posted image

Нет ничего настолько исправного, чтобы в нем не было ошибок. /Ф. Петрарка/ 
PM MAIL ICQ Skype   Вверх
php5
Дата 8.2.2010, 23:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Ну в принципе я такое тоже могу замутить , но ведь в таком случаи  нужно  заново делать  запрос к БД, а хотелось бы делать локально сортировку 
PM MAIL   Вверх
vikaz
Дата 9.2.2010, 06:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



В большинстве своем случаем при работе с БД, компоненты добавляют к запросу order by, самостоятельно! Имхо тоже самое.


--------------------
user posted image

Нет ничего настолько исправного, чтобы в нем не было ошибок. /Ф. Петрарка/ 
PM MAIL ICQ Skype   Вверх
mrbrooks
Дата 9.2.2010, 08:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

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



Цитата(vikaz @  9.2.2010,  06:03 Найти цитируемый пост)
В большинстве своем случаем при работе с БД, компоненты добавляют к запросу order by, самостоятельно! 

Фиг его знает камрад. Работа может вестись и с кешем.
php5, вообще если нет вложенного функционала у контрола - тогда только так, как советует vikaz. В противном случае надо юзать сторонние компоненты (вполне вероятно - платные) такие как DevExpress. Там, если не ошибаюсь, есть все - о чем можно только мечтать в быдлогуе.
PM MAIL   Вверх
vikaz
Дата 9.2.2010, 13:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(mrbrooks @  9.2.2010,  10:40 Найти цитируемый пост)
Фиг его знает камрад. Работа может вестись и с кешем.

smile  Согласен! smile


--------------------
user posted image

Нет ничего настолько исправного, чтобы в нем не было ошибок. /Ф. Петрарка/ 
PM MAIL ICQ Skype   Вверх
Лена
Дата 9.2.2010, 14:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



На сайте производителя, выложен пример Sorting a DB grid by clicking a column header
http://www.tmssoftware.com/site/dbadvgrd.asp?s=faq
может поможет.
PM MAIL   Вверх
php5
Дата 11.2.2010, 11:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(Лена @ 9.2.2010,  14:20)
На сайте производителя, выложен пример Sorting a DB grid by clicking a column header
http://www.tmssoftware.com/site/dbadvgrd.asp?s=faq
может поможет.

пример для  ADOSort почему-то не работает, а  BDESort реализован по принципу которой  предложил  vikaz. Скачал  компонент DevExpress v48  для  RAD Studio 2010  в Delphi проект с  компонентом компилируется,  а   builder –е  при компиляции получаю ошибки :
Код


[BCC32 Error] Dxuxtheme.hpp(114): E2238 Multiple declaration for 'BPBF_TOPDOWNDIB'
[BCC32 Error] Dxuxtheme.hpp(112): E2344 Earlier declaration of 'BPBF_TOPDOWNDIB'
[BCC32 Error] Dxuxtheme.hpp(114): E2444 Member 'BPBF_TOPDOWNDIB' is initialized more than once
Код

После того как я закомментировал в  Dxuxtheme.hpp  строку  static const ShortInt BPBF_COMPOSITED = 0x2;  то получаю ошибку   

access violation at address 00378FB7 in module 'dxGDIPlusD14bpl' Read of address 00000010

Пытался установить  компонент чисто из  builder –а, но  при попытки открыть  файл 
*С14.bpk появляется ошибка "Access violation at address 207FD68F in module 'coreide140.bpl'. Read of address 00000000."   Как этот компанет установить в Builder ?


Это сообщение отредактировал(а) php5 - 11.2.2010, 11:36
PM MAIL   Вверх
deltas
Дата 30.3.2010, 22:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Привет! Тоже пользуюсь DBAdvGrid, хоть и глючная но красивая штука smile

Чтоб работал Sort  установить  PageMode:=false
PM MAIL   Вверх
deltas
Дата 31.3.2010, 01:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Хотя с PageMode:=false появляются другие проблеммы... smile 
Параметр отвечает за связь с DataSource.

Решил другим путем, сортирую саму таблицу - 
Код


procedure TForm1.DBAdvGrid1ClickSort(Sender: TObject; ACol: Integer);
begin
 ADOTable1.Sort:=ADOTable1.Fields[Acol].FieldName +' ASC';
end;



Вместо ' ASC' можно ' DESC' (наоборот)...

Только если в ячейках есть пробелы вылетает ошибка... кто подскажет как исправить?
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

Запрещается!

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

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

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


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

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


 




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


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

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