Главная страница
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.009 c
4-1204870208
soi.hash
2008-03-07 09:10
2009.02.08
Ждущий режим


8-1190441010
andreil
2007-09-22 10:03
2009.02.08
Помогите с DirectInput!


1-1207734351
9899100
2008-04-09 13:45
2009.02.08
TTreeView


2-1230311876
palich
2008-12-26 20:17
2009.02.08
двоичные деревья в паскале


15-1229321392
Slider007
2008-12-15 09:09
2009.02.08
С днем рождения ! 13 декабря 2008 суббота