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

Вниз

Динамически-создаваемые поля.   Найти похожие ветки 

 
DROWSY   (2010-06-08 15:01) [0]

Если добавлять поле типа fkLookup или fkCalculated в Fields динамически, то как правильно это сделать?
В обработчике события DataSet.BeforeOpen - добавить, в DataSet.AfterClose - удалить, или как-то иначе?


 
Медвежонок Пятачок ©   (2010-06-08 15:10) [1]

манипуляции с TFieldDefs до открытия датасета.


 
DROWSY   (2010-06-08 17:11) [2]

Спасибо!


 
DROWSY   (2010-06-08 17:18) [3]

Сделал так, верно?

procedure TdmMills.ibMillsBeforeOpen(DataSet: TDataSet);

var i : integer;
   look_fld : TStringField;
begin
 DataSet.Fields.Clear;
 DataSet.FieldDefs.Update;

 for i := 0 to DataSet.FieldDefs.Count -1 do
   DataSet.FieldDefs[i].CreateField(DataSet);

 look_fld := TStringField.Create(DataSet);
 look_fld.Size := 25;
 look_fld.FieldName := "TYP_STR";
 look_fld.FieldKind := fkLookUp;
 look_fld.KeyFields := "TYP";
 look_fld.LookupDataSet := ibMills_Type;
 look_fld.LookupKeyFields := "CODE";
 look_fld.LookupResultField := "TYPE_STR";
 look_fld.DataSet := DataSet;
end;


 
Медвежонок Пятачок ©   (2010-06-08 17:19) [4]

сначала филддефс.апдейт.
затем добавляем туда вычисляемые поля.
затем цикл и создание тфилд"ов
потом открываем


 
DROWSY   (2010-06-08 17:53) [5]

Большое спасибо, Медвежонок Пятачок, за ликбез! :)



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

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

Наверх




Память: 0.47 MB
Время: 0.009 c
15-1276201773
Юрий
2010-06-11 00:29
2010.09.05
С днем рождения ! 11 июня 2010 пятница


15-1273206482
12
2010-05-07 08:28
2010.09.05
С днем связи!


15-1276193680
AKE
2010-06-10 22:14
2010.09.05
Я забыл можно ли объявлять функцию внутри функции?


2-1276082458
Delphist2
2010-06-09 15:20
2010.09.05
workbooks в excel


2-1275945627
akosh12345
2010-06-08 01:20
2010.09.05
Удаление без рекурсии