Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Отфильтровать таблицу по вычисляемому полю, onCalcFields, onFilterRecord 
V
    Опции темы
Chyslyvchyk
  Дата 24.1.2007, 06:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Есть Table1 (THalcyonDataSet), в котором есть вычисляемое поле CASH:
Код

procedure TFormBankRec.Table1CalcFields(DataSet: TDataSet);
begin
   Table2.setkey;
   Table2.fieldbyname('code1').AsString := Table1.fieldbyname('code1').AsString;
   Table2.fieldbyname('code2').AsString := Table1.fieldbyname('code2').AsString;
   if Table2.gotokey then
   Table1CASH.Value := Table2.fieldbyname('cash').AsString;
end;


Нужно отфильтровать по условию:
Код

procedure TFormBankRec.Table1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
  If (Table1.fieldbyname('NAME').asstring[1] in ['R','P','B'])
     and (Table1.fieldbyname('ST').asstring <> 'Y')
     and (Table1.fieldbyname('CASH').asstring <> 'B')
  then Accept := True;
  else  Accept := False;
end;


Как выяснилось фильтровать по вычисляемому полю невозможно. 
Как тогда вывести нужные записи из таблицы? 
Query не предлагать.


--------------------
Простота - сестра таланта!
PM MAIL   Вверх
x77
Дата 27.1.2007, 03:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



только одно в голову пришло. после каждого переоткрытия (изменения) таблицы формировать динамический массив из Id, удовлетворяющих условиям фильтра. Id - суть ключевое поле. тогда в OnFilterRecord останется проверять, входит ли ключевое поле данной записи в сформированный массив.

все переоткрытие таблицы, конечно, замедлится. но вот фильтрация будет работать как бы не быстрее ;)


--------------------
Я никогда не сопротивлялся искушению, поскольку узнал: что мне
не нравится, то меня не искушает.
© Джордж Бернард Шоу (Ирландия)
PM MAIL ICQ   Вверх
dimazu
Дата 27.1.2007, 19:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Создать временную таблицу, в ней сделать физическое поле
CASH, при вычислениях заносить в него значения и фильтровать
уже по нему...
PM MAIL   Вверх
Chyslyvchyk
Дата 14.2.2007, 01:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(dimazu @ 27.1.2007,  19:46)
Создать временную таблицу, в ней сделать физическое поле
CASH, при вычислениях заносить в него значения и фильтровать
уже по нему...

Угу. Несколько людей подсказали такую идею. Ее и юзаю.


--------------------
Простота - сестра таланта!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

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

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


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


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

FAQ раздела лежит здесь!


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

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


 




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


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

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