Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 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)

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:58
Выполнено за 0.02 сек.