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

Вниз

Отфильтрованный cxGridDBTableView   Найти похожие ветки 

 
миникодер   (2008-12-10 12:37) [0]

Кто знает, как получить доступ к отфильтрованным данным в гриде.
Сам грид привязан к датасету через свойство DataController.Datasource
В отчете нужно отображать только те данные, которые отфильтрованы в гриде. Кто знает, как к ним получить доступ??
Заранее благодарен.


 
Jeer ©   (2008-12-10 13:08) [1]

В каком еще отчете, где здесь отчет ?
А данные берутся не из грида, а из датасета, там же и фильтруют обычно.


 
keymaster ©   (2008-12-10 13:24) [2]

В cxGrid есть встроенный экспорт данных.
Экспортирует данные отфильтрованные как надо.
Смотри модуль cxExportGrid4Link.pas


 
Илья Корстин ©   (2008-12-10 13:28) [3]

Работайте с View.DataController.FilteredRecordIndex и View.DataController.Filter


 
миникодер   (2008-12-10 14:28) [4]


> В каком еще отчете, где здесь отчет ?

В frxReport подключается датасет, который связан с гридом.
В гриде отображаются отфильтрованные данные, а в датасете полностью все строки. Мне нужно только отфильтрованные строки.


 
миникодер   (2008-12-10 14:44) [5]


> Работайте с View.DataController.FilteredRecordIndex и View.
> DataController.Filter

Вы бы не могли привести пример, каким образом получить отфильтрованные данные?


 
Jeer ©   (2008-12-10 15:03) [6]


> В frxReport подключается датасет,


Вот именно, он работает с датасетом, а не с отображаемыми данными.
Разработчики репорта должны были предусмотреть его работу с любыми навороченными гридами ?
Конечно же нет - они предусмотрели его работу со стандартными источниками данных.


 
Илья Корстин ©   (2008-12-10 15:11) [7]


> Вы бы не могли привести пример, каким образом получить отфильтрованные
> данные?

Да как хотите. Например, вот так:
 s := "";
 for i := 0 to View.DataController.FilteredRecordCount - 1 do
   s := s + View.DataController.Values[View.DataController.FilteredRecordIndex[i], ViewID.Index] + ",";
 SetLength(s, Length(s) - 1);

В итоге переменная s будет содержаться перечисления поля ID ("1, 3, 7, 12, 33")

Можете получить значение фильтра конкретного столбца:

vValue := View.DataController.Filter.FindItemByItemLink(Viewf1).Value;

и задать его в Filter / FilterSQL.

Решений много. Ваша задача: задать условия отбора/фильтрации в датасете, аналогичные гридовским


 
YurikGL ©   (2008-12-10 22:04) [8]

ExportGridToExcel экспортирует из cxGrid с учетом текущего фильтра.



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

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

Наверх




Память: 0.48 MB
Время: 0.008 c
2-1230284005
Шакал
2008-12-26 12:33
2009.02.08
Next


2-1230543206
Pavel
2008-12-29 12:33
2009.02.08
Вывод в таблицу имен столбцов


3-1214828875
Drowsy
2008-06-30 16:27
2009.02.08
Operation violates CHECK constraint on view or table


2-1230044352
bioss
2008-12-23 17:59
2009.02.08
Алгоритм для выделенияслов из строки


6-1198485123
DelphiN!
2007-12-24 11:32
2009.02.08
Определить IP адрес клиента через прокси