Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.10.05;
Скачать: CL | DM;

Вниз

доступ к данным подчиненной таблицы   Найти похожие ветки 

 
kopernik21187 ©   (2008-08-18 14:50) [0]

вопрос такой:
есть две связанные таблицы ADOTable1 и ADOTable2,а также ADODataSet1...
ADOTable1-главная,ADOTable2-подчиненная....
доступ к определенному полю ADOTable1 осуществляется так
AdoDataSet1.RecNo:=n;
edit1.text:=AdoDataSet1.FieldByName("наименование" ).value;
а как скажите пожалуйста как точно так же получить доступ
к определенному полю в подчиненной таблице?
Заранее спасибо всем ответившим


 
Sergey13 ©   (2008-08-18 16:22) [1]

> [0] kopernik21187 ©   (18.08.08 14:50)
> доступ к определенному полю ADOTable1 осуществляется так
> AdoDataSet1.RecNo:=n;

Это не есть хорошо (мягко сказать). У таблицы должно быть ключевое поле по значению которого и нужно искать/позиционироваться на запись методом locate. Если таблицы связаны М-Д связью, то после позиционирования в главной таблице можешь так-же читать значение из подчиненной.
edit2.text:=ADOTable2.FieldByName("наименование" ).value;

Очтается выяснить зачем тебе AdoDataSet1 и как он связан с твоими ADOTable-ми?


 
oldman ©   (2008-08-18 16:38) [2]


> а как скажите пожалуйста как точно так же получить доступ
> к определенному полю в подчиненной таблице?


Для начала: не к полю, а к записи.
Ведь в подчиненной таблице их может быть несколько.
А если одна, locate тебе в руки...


 
kopernik21187 ©   (2008-08-21 12:07) [3]


> Очтается выяснить зачем тебе AdoDataSet1 и как он связан
> с твоими ADOTable-ми?

ты прав ADODataSet1 не понадобился....двумя ADOTable и без locate....
суть задачи заключалась в Memo вывести запись поля ADOTable1 и соответствующие ей подчиненные записи из ADOTable2
сделал так

procedure TForm1.Button2Click(Sender: TObject);
var i,j: integer;
begin

for i:=1 to DataModule2.ADOTable1.RecordCount do
    begin
    DataModule2.ADOTable1.RecNo:=i;
    Memo1.Lines.Add("Организация: "+DataModule2.ADOTable1.fieldbyname("Наименование").value);
      for j:=1 to DataModule2.ADOTable2.RecordCount do
           begin
              DataModule2.ADOTable2.RecNo:=j;
              Memo1.Lines.Add("ИНН: "+DataModule2.ADOTable2.fieldbyname("ИНН").Value);
           end;

    end;

end;


 
MsGuns ©   (2008-08-21 14:09) [4]

Вся эта дребедень в 3 реализуется простым запросом (TADOdataSet) с одной связкой и никакие нагромождения мастер-деталов не нужны


 
Anatoly Podgoretsky ©   (2008-08-21 15:22) [5]

Ох и поимеешь ты гемороя с RecNo

И вопрос, а зачем тогда тут нужен ADOTable1?


 
kopernik21187 ©   (2008-08-21 16:11) [6]


> Вся эта дребедень в 3 реализуется простым запросом (TADOdataSet)
> с одной связкой и никакие нагромождения мастер-деталов не
> нужны

ты не мог бы код привести?честно гря с ADODataSet еще не работал....

> Ох и поимеешь ты гемороя с RecNo

верно!мне срочно просто нада было.....
> И вопрос, а зачем тогда тут нужен ADOTable1?

как зачем?это ж главная таблица.....


 
MsGuns ©   (2008-08-21 16:29) [7]

Справка в помощь. По АДО в самих компонентах, по SQL - в дельфишной Local SQL
Вполне исчерпывающе.


 
Anatoly Podgoretsky ©   (2008-08-21 16:54) [8]

> kopernik21187  (21.08.2008 16:11:06)  [6]

Это да, но по коду в ней может быть только одна запись.



Страницы: 1 вся ветка

Текущий архив: 2008.10.05;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.016 c
2-1219232190
AndreyBg
2008-08-20 15:36
2008.10.05
Проблема с изменением св-в компонент в реалтайм.


2-1219467347
apic
2008-08-23 08:55
2008.10.05
Создание папок


2-1219337052
boa
2008-08-21 20:44
2008.10.05
корректно ли такое динамич создание форм?


15-1218472441
Анонимщики
2008-08-11 20:34
2008.10.05
Шахматы


2-1218625101
Дмитрий
2008-08-13 14:58
2008.10.05
Как заполнить поле одной таблицы из другой - перенести данные