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

Вниз

Как динамически добавить поле типа Lookup в TClientDataSet?   Найти похожие ветки 

 
serg128   (2004-06-08 12:57) [0]

Т.е. я делаю следующее:

   TStringField *fld = new TStringField(Owner);
   fld->FieldKind = fkLookup;
   fld->Size = 200;
   fld->FieldName = "ANALIT";
   fld->KeyFields = "ID";            
   fld->LookupDataSet = ld;
   fld->LookupKeyFields = "SIID";    
   fld->LookupResultField = "ANAL";  
   fld->Name = "ldsAnalit";
   fld->DisplayWidth = 200;
   fld->DataSet = lds;

   lds = new TLocalDataSet(NULL, frmMain->Connection, sSQL, 20);
   lds->Fields->Add(fld);
   lds->FieldDefs->Update();
   lds->Open();

Потом, при проходе по DBGrid вылетает сообщение типа "Field ANALIT has no DataSet"? Помогите плиз, что я неправильно сделал?


 
Clickmaker ©   (2004-06-08 13:35) [1]


> fld->DataSet = lds;
>
>    lds = new TLocalDataSet(NULL, frmMain->Connection, sSQL,
> 20);

Поменяй местами эти строки
И вот это
lds->Fields->Add(fld);
lds->FieldDefs->Update();
здесь не нужно, достаточно
fld->DataSet = lds;


 
serg128   (2004-06-08 13:57) [2]

>  fld->KeyFields = "ID";    

Когда я открываю lds, он пишет, что поле ID не найдено, мне нужно наверно его как-то добавить, но как?


 
Шаман   (2004-06-08 14:26) [3]

Самое странное также :)



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

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

Наверх




Память: 0.47 MB
Время: 0.025 c
3-1086755105
HeathRow
2004-06-09 08:25
2004.07.04
Символ окончания строки


9-1078659133
MrAngel
2004-03-07 14:32
2004.07.04
HLSL и GLSL


1-1087852688
Ivanov
2004-06-22 01:18
2004.07.04
Полупрозрачная закраска


3-1085991505
ceval
2004-05-31 12:18
2004.07.04
Подскажите как посредствам ADOTable связать две таблицы


11-1076154241
Sewix
2004-02-07 14:44
2004.07.04
Мне нужно создать n EditBox’ов