Показать сообщение отдельно
  #7  
Старый 22.06.2014, 12:39
poison-bla poison-bla вне форума
Прохожий
 
Регистрация: 17.05.2013
Сообщения: 28
Версия Delphi: Delphi 7, XE5
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
А зачем из комбика это делать? Вы положите на форму компонент TDbLookupComboBox. Настройте для него свойство ListSource. И тогда при выборе значения из списка автоматом будет изменятся позиция в источнике данных. Для второй таблицы делаете тоже самое. Затем правильно заполняете для второй таблички свойства MasterSource и MasterFields.
Вот и все. Теперь все будет работать автоматом.
Извините, не правильно выразилась, я и использую DbLookupComboBox.
Объясню по подробнее.
В первом DbLookupComboBox у меня в ListSource подключена таблица Категории товаров, а в DataSource - таблица Расход, поле id_kat. И на его св-ве OnClick прописан такой вот фильтр
Код:
//включем фильтр при выборе группы продукта
DM.DataModule2.tTovari.Filtered:=true;
DM.DataModule2.tTovari.Filter:='id_kat='+ inttostr(DBLookupComboBox1.KeyValue);
//отключаем фильтр, если в выбранной категории нет продуктов
 if fTovari.DBGrid1.DataSource.DataSet.RecordCount=0 then
                                   begin ShowMessage('Список продуктов пустой, выберите другую категорию или заполните справочник "Продукты".');
                                   DM.DataModule2.tTovari.Filtered:=false;
                                   end;
Который фильтрует наименования товаров во втором DBLookupComboBox. Второй комбо: DataSource - таблица Расход, поле - товары.
А ListSource никак добавить не могу, пишет property already defined by lookup field.
Ответить с цитированием