| 
| 
 | Вопрос # 4 174/ вопрос решён / | 
 |  Доброго времени суток, уважаемые эксперты!Преамбула. Таблица  Ctrana родительская к таблице Subj. В Subj нужно добавить строку, одно из полей строки которое нужно сформировать по символьному списку из Ctrana и вернуть код элемента списка Ctrana.
 На форму бросил DBGrid, DBCtrlGrid, DBNavigator настроил на Subj.
 На DBCtrlGrid поместил DBEdit и DBComboBox. Если редактировать строку вводить символьные данные и коды то нет проблем.
 Проблема в том, что необходимо в список  DBComboBox поместить столбец Ctrana.
 Настраиваю DBComboBox на таблицу Ctrana- затык.
 HELP ME!
 
|  |   Вопрос задал: Александр_К (статус: Посетитель)Вопрос отправлен: 17 мая 2010, 08:14
 Состояние вопроса: решён, ответов: 2.
 |  Ответ #1. Отвечает эксперт: Егор Здравствуйте, Александр_К!Надо использовать не DBComboBox, а DBLookupComboBox. Т.к. структура таблиц описана неполно, то предположу, что в таблице Subj есть поле subj_id_ctrana, а в таблице Ctrana есть поля ctrana_id_ctrana и ctrana_name
 
 Тогда настройка будет следующей:
 
 1. нам нужны два DataSource - один будет подключен к таблице с субъектами, второй - к таблице со странами
 2. свойство DataSource - указываем DataSource, который подключен к таблице subj
 3. свойство DataField - указываем поле из таблицы Subj, в котором хранятся номера стран - subj_id_crtana
 4. свойство ListSource - указываем DataSource, который подключен к таблице Ctrana
 5. свойство KeyField - указываем поле из таблицы Ctrana, в котором хранятся индексы стран - ctrana_id_ctrana
 6. свойство ListField - вот здесь уже указываем то поле, где хранятся названия стран - ctrana_name
 
 уф, компилируем и идём пить пиво :)
 
|  | Ответ отправил: Егор (статус: 10-ый класс)Время отправки: 18 мая 2010, 23:56
 Оценка за ответ: 5
 |  Ответ #2. Отвечает эксперт: Vic Здравствуйте, Александр_К!Проще будет использовать обычный Combobox
 с вкладки Standard.
 Например так:
 Используем ADOQuery1 c запросом из таблицы Ctrana ('Select ID,Ctrana FROM Ctrana'),
 ADOCommand1 с текстом 'Insert INTO Subj (ID_PARENT) VALUES (:par)
 
 
 1. Заполним список
 //
 ComboBox1.Clear;
 while not ADOQuery1.Eof do
 begin
 ComboBox1.Items.Add(ADOQuery1.Fields[1].asString);
 ADOQuery1.Next;
 end;
 2. При выборе из списка нужного элемента позиционируем курсор на нужную строку набора данных ADOQuery1
 ADOQuery1.First;
 ADOQuery1.MoveBy(ComboBox1.ItemIndex);
 3. вносим запись в дочернюю таблицу c помощью ADOCommand1
 ADOCommand1.Parameters[0].Value:=ADOQuery1.Fields[0].asInteger;
 ADOCommand1.Execute;
 
|  | Ответ отправил: Vic (статус: 1-ый класс)Время отправки: 19 мая 2010, 18:02
 Оценка за ответ: 5
 |  
 Мини-форум вопросаВсего сообщений: 2; последнее сообщение — 24 мая 2010, 18:24; участников в обсуждении: 2. 
|   | Александр_К (статус: Посетитель), 24 мая 2010, 08:47 [#1]:Спасибо  Егор и  Vic за помощь! |  
|   | Егор (статус: 10-ый класс), 24 мая 2010, 18:24 [#2]:обращайся ещё   Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.— Donald E. Knuth.
 |  31 января 2011, 19:36: Статус вопроса изменён на решённый (изменил модератор Ерёмин А.А.): Автоматическая обработка (2 и более ответов с оценкой 5) Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |