Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: СУБД и Delphi/Lazarus

  Все выпуски  

RusFAQ.ru: СУБД и Delphi


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Шичко Игорь
Статус: Студент
Рейтинг: 253
∙ повысить рейтинг >>
Виктор Пырлик
Статус: Профессионал
Рейтинг: 72
∙ повысить рейтинг >>
Командин Константин Евгениевич
Статус: 5-й класс
Рейтинг: 27
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / СУБД и Delphi

Выпуск № 516
от 19.11.2008, 04:05

Администратор:Gh0stik
В рассылке:Подписчиков: 253, Экспертов: 22
В номере:Вопросов: 1, Ответов: 2

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 150417: Уважаемые эксперты. У меня две связанные таблицы (связь:один-ко-многим). Как правильно обратиться к таблице, так чтобы, при выборе значения из Combobox в ListBox отображалась бы её связь? Мне бы хотя бы хоть какую-нибудь наводку, потому что даже не ...


Вопрос № 150.417
Уважаемые эксперты. У меня две связанные таблицы (связь:один-ко-многим). Как правильно обратиться к таблице, так чтобы, при выборе значения из Combobox в ListBox отображалась бы её связь? Мне бы хотя бы хоть какую-нибудь наводку, потому что даже не представляю с чего начать.
Отправлен: 13.11.2008, 11:33
Вопрос задала: Шушкова Марина Сергеевна (статус: Посетитель)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 1)

Отвечает: Шичко Игорь
Здравствуйте, Шушкова Марина Сергеевна!
Проще всего - это сделать следующее.
1. Добавить компонент ADOQuery1 (он будет использован для вывода данных в ListBox1)
2. Сделать обработчик события для Вашего ComboBox1. В нем примерно написать следующее
procedure TForm1.ComboBox1Select(Sender: TObject);
var
i: integer;
begin
ListBox1.Clear;
{Запрос ко второй таблице}

ADOQuery1.Close;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Text:= 'Select [нужное Вам поле из 2-й таблицы] from [имя 2-й таблицы] where [поле связи] =' + QuotedStr(ComboBox1.Text);
ADOQuery1.Open; ADOQuery1.First;
for i:= 1 to ADOQuery1.RecordCount do
begin
ListBox1.Items.Add(ADOQuery1.FieldByName([нужное Вам поле из 2-й таблицы]).AsString);
ADOQuery1.Next;
end;
ADOQuery1.Close;
end;

Примерно так.
Вопросы пишите в форум.
Ответ отправил: Шичко Игорь (статус: Студент)
Ответ отправлен: 13.11.2008, 12:56

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235380 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо, всё получилось!!!)))


    Отвечает: Виктор Пырлик
    Здравствуйте, Шушкова Марина Сергеевна!

    Сначала, надо заполнить значения ComboBox. Потом, определить его событие OnChange (просто щелкните дважды по нему мышкой). В приведенном коде это все есть.
    Код:
    {тут мы заполняем выподающий список значением}
    procedure TForm1.FormCreate(Sender: TObject); // это конструктор формы
    begin
    ComboBox1.Style := csDropDownList; // не редактируемый, выподающий список, пользователь может только выбирать.
    ComboBox1.Items.Clear; // очистим если что есть
    ADOTable1.Active:= true; // активируем таблицу
    ADOTable1.DisableControls; // запретим отображать изменения/перемещения по таблице
    ADOTable1.First; // установим курсор таблицы в самое начало
    while(not AdoTable1.Eof)do // пока не дости гнут конец таблицы
    begin
    ComboBox1.Items.Add(ADOTable1.fieldbyname('name_p').AsString); // добовляем значения по которым быдем фильтровать
    Adotable1.Next; // переместимся на одну запись в перед
    end;
    ADOTable1.EnableControls;// разрешаем контролы для таблицы
    ComboBox1.ItemIndex := 0;// устанавливаем первый элемент в ComboBox
    end;
    {это событие выбора в ComboBox}
    procedure TForm1.ComboBox1Change(Sender: TObject);
    begin
    ADOTable2.DisableControls; //отключаем контролы
    ADOTable2.Filtered := false; // отключаем фильтр
    ADOTable2.Filter := Format('pole1 = %s',[QuotedStr(ComboBox1.Text)]); // устанавливаем фильтр
    ADOTable2.Filtered := true;// включаем фильтр
    ADOTable2.First; // на первую запись
    ListBox1.Clear;// очистим лист
    while not ADOTable2.Eof do // пока есть что читать
    begin
    ListBox1.Items.Add(ADOTable2.FieldByName('ваше поле').AsString); // заносим в лист
    ADOTable2.Next; // на следующую запись
    end;
    ADOTable2.First; // если нет контролов, можно не использовать, иначе, вернемся в начало
    ADOTable2.EnableControls; // разрешим контролы (реакцию компонентов отображения связаных с таблицей)
    { для Query аналогично.}
    end;



    ---------
    не получается там - где не пробуют
    Ответ отправил: Виктор Пырлик (статус: Профессионал)
    Россия, Екатеринбург
    Тел.: 89043822027
    ICQ: 490191733
    ----
    Ответ отправлен: 13.11.2008, 17:10

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235410 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

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

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2008, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.11 от 9.11.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное